数据库课程实训报告-车辆租赁管理系统.doc_第1页
数据库课程实训报告-车辆租赁管理系统.doc_第2页
数据库课程实训报告-车辆租赁管理系统.doc_第3页
数据库课程实训报告-车辆租赁管理系统.doc_第4页
数据库课程实训报告-车辆租赁管理系统.doc_第5页
已阅读5页,还剩17页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

数据库课程实训(2017)数据库课程实训报告题目: 车辆租赁管理系统 1目 录目 录21 课题内容和要求11.1课题描述11.2 课题要求12 需求分析22.1 功能需求分析23 系统设计33.1 功能模块设计33.3 数据库逻辑设计53.4 数据库物理设计63.5 数据库表间联系74系统实现74.1 登陆界面模块实现74.2 司机信息模块实现84.3 客户租车信息模块实现95 代码调试与功能测试105.1 测试方案105.2 测试结果106 收获与体会15参考文献16附录17附录1源程序部分清单17附录1.1登陆代码17附录1.2 添加信息代码19附录1.3 修改信息代码19附录1.4 删除信息代码211租赁汽车租赁管理系统1 课题内容和要求 1.1课题描述因为客户只能亲自到汽车租赁公司去注册或租赁车辆,因而,两者权限分配如下:汽车公司方面:能够对车辆,租赁信息和用户信息进行管理。超级管理员还可以对公司内部人员的信息进行管理客户方面:只能浏览车辆信息和个人用户信息及个人租赁信息。1.2 课题要求基本功能要求:1) 可以对汽车基本信息进行增加、删除、修改2) 可以对租赁客户信息进行增加、删除、修改3) 可以实现汽车的租借、归还、续借4) 可以按重要字段查询汽车、客户等基本信息5) 可以实现租赁金额的计算6) 可以查询汽车、客户租赁历史记录2 需求分析2.1 功能需求分析不同权限的用户登录超级管理员内部人员管理客户信息管理车辆信息管理普通管理员客户信息管理车辆信息管理客户个人信息浏览车辆信息浏览租车信息浏览财务信息管理财务信息管理图2.1.1 总体功能设计模块2.2 数据需求分析2.2.1 管理员使用系统的人 管理员(loginButton1) =身份证号+姓名+住址+登陆密码2.2.2 客户租车的人 客户(loginButton2)=身份证号+姓名+年龄+地址+电话+登陆密码2.2.3 车辆信息车辆信息(carinformation)=车辆名称+车辆类型+购买时间+车辆状况+租金标准+租车起始时间+租期2.2.4 司机信息被雇佣的司机 司机信息(driver)=身份证号+姓名+年龄+地址+电话+驾驶证书管理员客户新增客户个人信息用户信息文件车辆新增交易车辆信息交易信息文件个人信息新增车辆车辆信息文件新增管理员内部人员管理人员信息文件图2.2.5 数据流图3 系统设计3.1 功能模块设计 管理员信息模块:管理员相关信息,包括身份证号、姓名、年龄、地址、电话、登陆密码相关信息,主要负责删除修改信息。车辆信息模块:包括车辆类型、车辆名称、购买时间、车辆状况、租凭、租金标准等可查询车辆类型、名称、购买时间、状况、租金标准等,并且可根据需要增加、删除、修改车辆的基本信息,还可根据车辆类型和车辆情况进行条件查询。客户信息模块:身份证号、姓名、年龄、地址、电话等。司机信息模块:身份证号、姓名、年龄、地址、电话、驾驶证书等。租金查询模块:车辆的租金和出租时间情况。3.2 数据库概念设计 管理员信息身份证号姓名电话住址登陆密码图3.2.1 管理员信息购买时间车辆状况车辆类型车辆名称租车时间租金标准租赁状况车辆信息图3.2.2车辆信息客户信息身份证号姓名电话住址登陆密码图3.2.3客户信息司机信息身份证号姓名电话住址登陆密码图3.2.4司机信息管理员管理管理管理租赁驾驶客户车辆司机 图3.2.5 ER关系图管理员管理车辆车辆租用车辆客 户1N管理用户工号用户名类型密码编号类型状态起租时间单价租用时间编号客户编号车辆编号经手人员起租时间押金租用时间返回金额状态证件号用户名会员类型密码MNnm信誉度图3.2.6全局E-R图3.3 数据库逻辑设计管理员(身份证号,姓名,电话,住址,登陆密码)司机(身份证号,姓名,年龄,地址,电话,驾驶证书)车辆(车辆名称,车辆类型,购买时间,车辆状况,租金标准,租金起始时间,租期)客户(身份证号,姓名,电话,住址,登陆密码)3.4 数据库物理设计 表3.4.1 adminMessage(管理员信息表)字段名称数据类型字段大小姓名Varchar50电话Varchar50住址Varchar50身份证Varchar50登录密码Varchar50表3.4.2 carMessage(车辆信息表)字段名称数据类型字段大小车辆名车Varchar50购买时间Varchar50车辆状况Varchar50租金标准Varchar50租期起始时间Varchar50租期Varchar50表3.4.3 userMessage(客户信息表)字段名称数据类型字段大小身份证Varchar50姓名Varchar50年龄Varchar50地址Varchar50电话Varchar50登录密码Varchar50表3.4.4 driverMessage(司机信息表)字段名称数据类型字段大小身份证varchar50姓名varchar50年龄varchar50地址varchar50电话varchar50驾驶证书varchar503.5 数据库表间联系 图3.5.1 数据表间联系4系统实现4.1 登陆界面模块实现图4.1.1 登录界面本界面采用Flowlayout流式布局,其中通过JFrame frame=new JFrame(车辆租赁管理系统)给界面添加标题“车辆租赁管理系统”,通过new Jlable 来添加两个标签用户名和密码,通过label1.setFont(new java.awt.Font(微软雅黑,0,16);给输入的字体建立长度大小和格式,通过new JButton建立3个按钮分别是管理员登陆、客户登陆和退出,通过new JTextField分别给用户名和密码增加文本区,对于3个按钮通过采用new ImageIcon给按钮增加图标,使用户更加清晰的辨认按钮,增加背景图片,使登陆界面更加美观。本界面采用ActionListener接口,ActionListener用于接收操作事件的侦听器接口。对处理操作事件感兴趣的类可以实现此接口,而使用该类创建的对象可使用组件的 addActionListener 方法向该组件注册。在发生操作事件时,调用该对象的 actionPerformed 方法。本界面采用actionPerformed方法调用的ActionEvent e事件监听器来处理单击鼠标时发生的事件。本界面采用getText()函数:返回数据窗口控件中悬浮在当前行列之上的编辑框中的文本。在用户修改数据窗口中某项的值时,实际上首先在悬浮 在当前项上的编辑框中进行修改 , 当用户移动输入焦点或程序中使用 AcceptText()函数接收用户输入时,用户修改的数据通过if(username.getText().equals(*)=true)&(password.getText().equals(*)=true)来验证用户名密码是否正确,如果正确,则成功进入下一个界面,如果失败会在屏幕上显示登陆失败。4.2 司机信息模块实现图4.2.1 司机信息 本界面使用的Flowlayout流式布局,其中通过JFrame frame=new JFrame(司机信息)给界面添加标题“司机信息”,添加6个按钮分别是添加、修改、删除、查询所有、查询个人信息、返回,使用Jlable6个标签身份证号、姓名、年龄、地址、电话。本界面采用ActionListener接口,ActionListener用于接收操作事件的侦听器接口。对处理操作事件感兴趣的类可以实现此接口,而使用该类创建的对象可使用组件的 addActionListener 方法向该组件注册。在发生操作事件时,调用该对象的 actionPerformed 方法。本界面采用actionPerformed方法调用的ActionEvent e事件监听器来处理单击鼠标时发生的事件。本界面采用getText()函数:返回数据窗口控件中悬浮在当前行列之上的编辑框中的文本。在用户修改数据窗口中某项的值时,实际上首先在悬浮 在当前项上的编辑框中进行修改 , 当用户移动输入焦点或程序中使用 AcceptText()函数接收用户输入时,用户修改的数据通过if(username.getText().equals(*)=true)&(password.getText().equals(*)=true)来验证用户名密码是否正确,如果正确,则成功进入下一个界面,如果失败会在屏幕上显示登陆失败。数据库连接:其中采用Connection con对象进行连接数据库 con=DriverManager.getConnection(jdbc:sqlserver:/localhost:1433;DatabaseName=bl,sa,123456);连接的数据库名为bl,用户名为sa,密码为123456.数据库连接之前要进行一系列配置,例如系统程序功能中的启动Telnet客户端,将SQL配置管理器的TCP/IP启用,到之后的环境变量的配置,直至连接完成。 删除功能:利用getText()采集用户所输入的字符,然后再利用sql语句SELECT * FROM 司机信息 order by 身份证号 desc,进行删除,如果输入字符是数据库里存在的列名且相等的话则显示删除成功,如果不存在或不相等的话则显示删除失败,如果用户没有输入的话,用getText().compareTo()=0)进行比对,如果等于0则表示用户没输入字符,提示:请输入“*”。 添加,修改功能和删除功能类似。4.3 客户租车信息模块实现图4.3.1 客户租车信息模块实现本界面采用Flowlayout流式布局,其中通过JFrame frame=new JFrame(客户租车)给界面添加标题“客户租车”,采用JComboBox组件以及scrollpane下拉框,添加司机信息、租赁车辆、租赁、雇佣司机、注销等按钮,其中添加复选框日租和月租。数据库连接同司机信息模块。本模块可实现客户进行雇佣司机和租车。5 代码调试与功能测试5.1 测试方案通过程序登陆窗口登陆进入界面对司机信息、客户信息、车辆信息、租金信息进行修改、删除等操作5.2 测试结果图5.2.1 登陆界面图5.2.2 系统界面图5.2.3 车辆信息界面图5.2.4 客户信息界面图5.2.5 司机信息界面图5.2.6租金信息界面图5.2.7 系统统计界面图5.2.8 客户租车界面图5.2.9 删除信息界面图5.2.10 删除界面6 收获与体会两周的时间很快就过去了,这两周我不敢说自己有多大的进步,获得多少知识,但起码了解了项目开发的部分过程。虽说上过数据库相关的课程,但是没有亲身经历相关的设计工作细节。这次课程设计给我提供了一个很好的机会。通过这次课程设计发现这其中需要的很多知识我们没有接触过,上网查找资料的时候发现我们学习过的都只是皮毛。这次实验让我明白了不管做什么事情,不要畏惧,不要怕遇到困难。 19参考文献1 钱雪忠,王燕玲,林挺.数据库原理及技术M.北京:清华大学出版社,2011.2 钱雪忠,罗海驰,陈国俊.数据库原理及技术课程设计M.北京:清华大学出版社,2014.3 高飞,陆佳炜,徐俊,赵小敏.Java程序设计实用教程M.北京:清华大学出版社.2013.4 王珊,萨师道.数据库系统概论M.北京:高等教育出版社,2006.5 刘金岭,冯万利数据库系统及应用教程M北京:清华大学出版社,2013.6 刘金岭,冯万利,周泓数据库系统及应用实验与课程设计指导M北京:清华大学出版社,2013.附录附录1源程序部分清单附录1.1登陆代码import java.awt.event.ActionListener;import java.awt.Color;import java.awt.Dimension;import java.awt.FlowLayout;import java.awt.Toolkit;import java.awt.event.ActionEvent;import java.io.IOException;import java.sql.Connection;import java.sql.DriverManager;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;import java.util.Vector;import javax.swing.*;public class dl implements ActionListener JFrame frame=new JFrame(车辆租赁管理系统);JLabel label1=new JLabel(用户名);JLabel label2=new JLabel(密码);ImageIcon jbi1=new ImageIcon(image/admin.png);ImageIcon jbi2=new ImageIcon(image/admin2.png);ImageIcon jbi3=new ImageIcon(image/quit.png);JButton loginButton1=new JButton(管理员登陆,jbi1);JButton loginButton2=new JButton(客户登陆,jbi2);JButton cancelButton=new JButton(退出,jbi3);JTextField t1=new JTextField(0);JTextField t2=new JTextField(0);ImageIcon im=new ImageIcon(image/10.jpg);JLabel a2=new JLabel(im);JTextField username=new JTextField(9);JPasswordField password=new JPasswordField(9);void create()JPanel p=(JPanel)frame.getContentPane();JPanel p1=new JPanel();p.setLayout(new FlowLayout();p.add(label1);/*用户名*/label1.setFont(new java.awt.Font(微软雅黑,0,16);p.setSize(5,5);p.setLocation(4,8);p.add(username);username.setFont(new java.awt.Font(微软雅黑,0,14);System.out.println(n);p.setSize(100,200);p.setLocation(800,800);p.add(label2);/*密码 */label2.setFont(new java.awt.Font(微软雅黑,0,16);p.setSize(50,20);p.setLocation(60, 80);p.add(password);p.setSize(100,20);p.setLocation(80, 120);loginButton1.setFont(new java.awt.Font(微软雅黑,0,14);p.add(new JLabel( );p.add(new JLabel( );p.add(loginButton1);/*管理员登陆 */loginButton2.setFont(new java.awt.Font(微软雅黑,0,14);p.add(loginButton2);/*客户登陆*/p.add(cancelButton);/*退出*/cancelButton.setFont(new java.awt.Font(微软雅黑,0,14);/p.add(t1);/p.add(t2);p.setBackground(new java.awt.Color(255,255,255);p.add(a2);p.add(new JLabel( );/p.setBackground(Color.red);p.setVisible(true);loginButton1.addActionListener(this);loginButton2.addActionListener(this);cancelButton.addActionListener(this);frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);frame.pack();Toolkit toolkit=Toolkit.getDefaultToolkit();Dimension d=toolkit.getScreenSize();frame.setBounds(d.width/2-375, d.height/2-225, 750, 450);/frame.setBounds(200,100,750,550);frame.setVisible(true);public static void main(String args) dl dome=new dl(); dome.create(); public void actionPerformed(ActionEvent e)if(cancelButton.equals(e.getSource()System.exit(0);if(loginButton1.equals(e.getSource()if(username.getText().equals(*)=true)&(password.getText().equals(123)=true)ZJM gz=new ZJM();gz.create();frame.setVisible(false);elseJOptionPane.showMessageDialog(null,登录失败!);if(loginButton2.equals(e.getSource()System.out.print(123123);if(username.getText().equals(121)=true)&(password.getText().equals(123)=true)KHZC gz=new KHZC();gz.create();frame.setVisible(false);elseJOptionPane.showMessageDialog(null,登录失败!);附录1.2 添加信息代码public void actionPerformed(ActionEvent e)if(b1.equals(e.getSource()/ 添加Connection con;Statement sql;ResultSet rs;tryClass.forName(com.microsoft.sqlserver.jdbc.SQLServerDriver);catch(ClassNotFoundException e1)System.out.println(+e1);trycon=DriverManager.getConnection(jdbc:sqlserver:/localhost:1433;DatabaseName=bl,sa,123456);sql=con.createStatement();String insertStr=INSERT INTO 车辆信息 VALUES+(+tf1.getText()+,+tf2.getText()+,+tf3.getText()+,+tf4.getText()+,+tf5.getText()+,+null+,+null+);if(!sql.execute(insertStr)JOptionPane.showMessageDialog(null,录入成功!);tf1.setText(null);tf2.setText(null);tf3.setText(null);tf4.setText(null);tf6.setText(null); con.close();catch(SQLException e1)JOptionPane.showMessageDialog(null,录入失败!);System.out.println(e1);附录1.3 修改信息代码if(b2.equals(e.getSource()Connection con;Statement sql;ResultSet rs;tryClass.forName(com.microsoft.sqlserver.jdbc.SQLServerDriver);catch(ClassNotFoundException e1)System.out.println(+e1);trycon=DriverManager.getConnection(jdbc:sqlserver:/localhost:1433;DatabaseName=bl,sa,123456);sql=con.createStatement();bl.ud=false;String x=tf1.getText();x.replace( , );if(tf2.getText().compareTo()!=0&tf1.getText().compareTo()!=0)bl.ud=true;if(sql.executeUpdate(UPDATE 车辆信息 SET 车辆类型=+tf2.getText()+WHERE 车辆名称=+x+)!=1)bl.ud=false;if(tf3.getText().compareTo()!=0&tf1.getText().compareTo()!=0)bl.ud=true;if(sql.executeUpdate(UPDATE 车辆信息 SET 购买时间=+tf3.getText()+WHERE 车辆名称=+x+)!=1)bl.ud=false;if(tf4.getText().compareTo()!=0&tf1.getText().compareTo()!=0)bl.ud=true;if(sql.executeUpdate(UPDATE 车辆信息 SET 车辆状况=+tf4.getText()+WHERE 车辆名称=+x+)!=1)bl.ud=false;if(tf5.getText().compareTo()!=0&tf1.getText().compareTo()!=0)bl.ud=true;if(sql.executeUpdate(UPDATE 车辆信息 SET 租金标准=+tf5.getText()+WHERE 车辆名称=+x+)!=1)bl.ud=false;if(tf2.getText().compareTo()=0&tf3.getText().compareTo()=0&tf4.getText().compareTo()=0&tf5.getText().compareTo()=0)&tf1.getText().compareTo()!=0)JOptionPane.showMessageDialog(null,数据有误或没填写更新所需数据!);if(bl.ud&tf1.getText().compareTo()!=0)JOptionPane.showMessageDialog(null,修改成功!);tf1.setText(null);tf2.setText(null);tf3.setText(null);tf4.setTe

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论