(汽车行业)数据库课程设计报告(汽车租赁管理系统)

上传人:管****问 文档编号:127849505 上传时间:2020-04-06 格式:DOC 页数:15 大小:335.57KB
返回 下载 相关 举报
(汽车行业)数据库课程设计报告(汽车租赁管理系统)_第1页
第1页 / 共15页
(汽车行业)数据库课程设计报告(汽车租赁管理系统)_第2页
第2页 / 共15页
(汽车行业)数据库课程设计报告(汽车租赁管理系统)_第3页
第3页 / 共15页
(汽车行业)数据库课程设计报告(汽车租赁管理系统)_第4页
第4页 / 共15页
(汽车行业)数据库课程设计报告(汽车租赁管理系统)_第5页
第5页 / 共15页
点击查看更多>>
资源描述

《(汽车行业)数据库课程设计报告(汽车租赁管理系统)》由会员分享,可在线阅读,更多相关《(汽车行业)数据库课程设计报告(汽车租赁管理系统)(15页珍藏版)》请在金锄头文库上搜索。

1、一 系统简介 本系统为汽车租赁系统,采用B/S实现。可以实现不同权限的浏览和管理。管理员可以用于汽车租赁公司对汽车租赁事务的管理,包括新增、删除车辆记录,新增、删除用户记录,新增、删除租赁信息记录,新增、删除管理人员记录以及会员设置,客户则可以浏览车辆信息和个人的租车信息。 主要技术:jsp运行环境:winows os+apache tomcat5.5+sql server 2005+jdk1.6开发软件:myeclipse6.0.1开源软件:jxl.jar,sqljdbc4.jar二 数据库设计1. 需求分析因为客户只能亲自到汽车租赁公司去注册或租赁车辆,因而,两者权限分配如下:汽车公司方面

2、:能够对车辆,租赁信息和用户信息进行管理。超级管理员还可以对公司内部人员的信息进行管理客户方面:只能浏览车辆信息和个人用户信息及个人租赁信息。数据流图如下: 管理员客户新增客户个人信息用户信息文件车辆新增交易车辆信息交易信息文件个人信息新增车辆车辆信息文件新增管理员内部人员管理人员信息文件2. 概念设计ER图如下所示: 管理员管理车辆车辆租用车辆客 户1N管理用户工号用户名类型密码编号类型状态起租时间单价租用时间编号客户编号车辆编号经手人员起租时间押金租用时间返回金额状态证件号用户名会员类型密码MNnm信誉度3. 逻辑设计建表语句如下:用户表:/后为各字段意义声明create table us

3、erinfo( pid varchar(8) primary key, /用户证件号 username varchar(8), /用户名 isvip int, /用户类型,是否为会员 xingyu int, /信誉度,满分100。 password varchar(8) /用户登录密码);管理员表:create table manager( wid varchar(8) primary key, /管理员工号 type int, /类型,超级管理员(部门经理等)和普通管理员 username varchar(8), /管理员用户名 password varchar(8) /管理员密码);车辆表

4、:create table taxi( tid varchar(8) primary key,/车辆编号 type varchar(8), /车辆类型 state varchar(8), /车辆状态,是否可租 wid varchar(8), / year int, /起租年月日 month int, day int, time int, detailinfo text, /车辆详细信息 pay int /租用单价);租车信息表create table rentinfo( rid int identity(1,1) primary key, /交易编号 wid varchar(8), /经手人员

5、 pid varchar(8), /客户证件号 tid varchar(8),/ 车辆号码 yajin int, /押金 backmoney int, /返还金额 pay int,/单价 broken varchar(8),/破坏情况 outyear int,/结束交易时间 outmonth int, outday int, time int,/实际使用时间 state varchar(8)/交易状态 );-设置外键BEGIN TRANSACTIONalter table dbo.rentinfo add constraint FK_rentinfo_tidforeign key (tid)r

6、eferences dbo.taxi(tid) alter table dbo.rentinfo add constraint FK_rentinfo_pidforeign key (pid)references dbo.userinfo(pid) alter table dbo.rentinfo add constraint FK_rentinfo_widforeign key (wid)references dbo.manager(wid) COMMIT TRANSACTION4. 数据库建立与备份,恢复在sql server 2005 建立一个数据库,名称为hello,执行以上建表语句即

7、可。或者将hello.mdf,hello_log.ldf文件恢复。sp_attach_db hello, C:Program FilesMicrosoft SQL ServerMSSQLDatahello.mdf, C:Program FilesMicrosoft SQL ServerMSSQLDatahello_log.ldf sp_attach_single_file_db hello,C:Program FilesMicrosoft SQL ServerMSSQLDatahello.mdf备份:将hello数据库备份成hello.bak文件三 框架实现 系统总体框架实现如下图所示: 不同

8、权限的用户登录超级管理员内部人员管理客户信息管理车辆信息管理普通管理员客户信息管理车辆信息管理客户个人信息浏览车辆信息浏览租车信息浏览财务信息管理财务信息管理以下是各模块的子功能截图:登录模块截图: 超级管理员页面截图:普通管理员页面截图:员工信息管理页面截图:员工 信息管理(单表查询)员工业绩查询(多表查询)增加员工(单表插入数据)修改个人密码客户信息管理:交易信息查询(多表查询)客户信息查询车辆信息管理:新增车辆信息车辆信息查询财务信息查询:数据操作实现方法: 定义一个类DataManager,在每个jsp页面中实例化这个类,并调用它的某个方法,完成数据库的连接,数据查询,删除,及修改操作

9、。程序示例:如check.jsp里面可以验证用户登录信息,并转向不同页面。DataManager dm = new DataManager();/实例化DataManager类ResultSet rs = null;if (type = 1) /如果是以客户身份登录String sql = select * from userinfo where username= + username+ + and password = + password + ;rs = dm.getResult(sql);/由用户名和密码获取记录if (rs.next() /如果记录不为空,表明该客户存在String

10、pid = rs.getString(pid);/保存该用户信息session.setAttribute(type, 1);session.setAttribute(pid, pid);session.setAttribute(username, username);response.sendRedirect(user.jsp);/转向客户页面 else /转向管理员页面,以下与上面if语句类似。String sql = select * from manager where username=+ username + + and password = + password+ and type

11、 =+type;System.out.println(sql);rs = dm.getResult(sql);if (rs.next() String wid = rs.getString(wid);session.setAttribute(type, t);session.setAttribute(wid, wid);session.setAttribute(username, username);response.sendRedirect(manager.jsp);此外,系统具有良好的安全性,对每个页面都有良好的保护措施,如manashare.jsp,usershar.jsp,通过sess

12、ion验证用户有无权限进入该页面,否则跳转到login.jsp页面,重新登录。四 程序设计 1.含有表单的jsp页面可以通过设置隐藏域的值来提交到本页面,其程序流程如下:开始获得隐藏域变量的值为空?表单的填写跳转到本页显示表单提交结果结束YN2.财务管理中有个导出execl报表的功能,其实现如下: 从网上下载一个jxl.jar包,该jar包支持生成execl文件的操作,然后建立一个专门的类,用于生成execl,该类源码如下:package my.pkgs;import java.io.*; import jxl.*; /jxl.jar里面的类库import jxl.write.*; impor

13、t java.sql.*;public class CreateXLS public String create(ResultSet rs,String filename) tryFile f = new File(filename);boolean exist = f.exists();WritableWorkbook book = Workbook.createWorkbook(new File(filename);/生成名为“第一页”的工作表,参数0表示这是第一页 WritableSheet sheet = book.createSheet(第一页, 0);/在Label对象的构造子中指名单元格位置是第一列第一行(0,0) /以及单元格内容为test Label label0 = n

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 商业/管理/HR > 经营企划

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号