1、长 沙 学 院课程设计说明书题目汽车租赁管理系统学院计数院专业(班级)软件工程姓名学号指导老师杨刚、潘怡起止日期/5/29-/6/29课程设计任务书课程名称:数据库系统原理课程设计设计题目:汽车租赁管理系统。已知技术参数和设计要求:题目:汽车租赁管理系统1、 某汽车租赁企业汽车租赁管理系统需要以下信息:工作人员信息包含:工号、姓名、性别、联络电话等。用户信息包含:身份证号、姓名、性别、所在单位、联络电话等。车辆信息包含:车牌号、品牌、颜色、座位数、日租价格、日租超公里价格、月租价格、租赁状态、购入日期等。车辆类别信息包含:分类号,库存数。其业务规则描述以下:一个工作人员能够对很多辆车辆进行管理
2、,一辆车也能够被多个工作人员管理;一辆车只能属于一个车辆类别,而一个车辆类别能够包含多辆车;一个用户能够租多辆不一样车。2、系统功效基础要求:能够实现对车辆、租赁用户查询,能够查询汽车、用户租赁历史统计。能够按类别统计汽车租赁金额和剩下库存数,能够统计某十二个月纪用户群体对某类汽车租赁喜好,能模拟用户对汽车租借、归还业务。各阶段具体要求:1、需求分析阶段l 定义数据项含义和取值l 定义目标系统数据流2、概念结构设计阶段l 画出实体模型E-R图3、逻辑结构设计阶段l 将实体模型转化为关系模型l 给出每个关系主关键字和函数依靠集l 分析你所设计关系数据库模式是否属于3NF4、物理设计阶段l 确定全
3、部字段名称、类型、宽度、小数位数及完整性约束 l 确定数据库及表名称及其组成 l 确定索引文件和索引关键字5、数据库安全及维护设计阶段l 设计一个适合数据库安全策略(用户身份认证、访问权限、视图)l 为了实现复杂数据完整性约束,设计合适触发器l 设计一个适合数据库备份策略6、实施阶段l 要求全部操作必需在查询分析器中用SQL语句或系统存放过程完成。设计工作量:(1)软件设计:完成问题陈说中所提到全部需求功效。(2)论文:要求撰写不少于3000个文字电子文档,具体说明各阶段具体要求。工作计划:安排两周时间进行课程设计,软件开发步骤以下,第一周完成14,第二周完成58,论文同时进行;1)选定题目2
4、)需求分析3)概念结构设计4)逻辑结构设计5)物理设计6)数据库安全及维护设计7)数据库上机实现8)答辩计划时间指导老师班级1516周潘怡、杨刚15软件1班1516周潘怡、杨刚15软件2班1516周卓琳、田清龙15软件3班1516周卓琳、田清龙15软件4班1516周张肖霞、马丽15软件5班1516周张肖霞、马丽 15软件6班注意事项n 提交电子文档 长沙学院课程设计任务书(每学生1份) 长沙学院课程设计论文(每学生1份) 长沙学院课程设计判定表(每学生1份)指导老师署名: 日期: 教研室主任署名: 日期:院长署名: 日期: 长沙学院课程设计判定表姓名学号专业班级设计题目指导老师指导老师意见:评
5、定等级: 老师署名: 日期: 答辩小组意见:评定等级:答辩小组长署名:日期:教研室意见:教研室主任署名: 日期: 学院意见:院长署名:日期:说明课程设计成绩分“优异”、“良好”、“及格”、“不及格”四类;目 录一、引言71.1编写目标71.2参考资料7二、需求规约72.1 业务描述72.2 需求分析8三、数据库环境说明8四、数据库命名规则83.1 数据库对象命名规则83.2 数据项编码规则9五、逻辑设计105.1创建和数据库相关那部分实体关系图(ERD)、表及关系图105.2创建数据库系统关系模型12六、物理设计126.1表汇总126.2存放过程176.3触发器21七、安全性设计287.1预防
6、用户直接操作数据库方法287.2角色和权限28八、数据库管理和维护说明29九、附录:源代码30一、引言1.1 编写目标本文档是汽车租赁系统设计文档组成部分,编写数据库设计文档目标是:明确数据库表名、字段名等数据信息,用来指导后期数据库脚本开发。本文档读者对象是需求人员、系统设计人员、开发人员、测试人员。1.2 参考资料资料名称作者文件编号、版本数据库系统概论王珊、萨师煊5月第4版二、 需求规约2.1 业务描述2.1.1数据库创建背景该数据库建立于sq l server r2,环境为windows7系统名称:汽车租赁管理系统。系统开发者:小组组员系统用户:租车用户和租赁企业工作人员。2.1.2
7、数据库系统要完成业务步骤及工作内容 首先完成需求分析,依据需求关系画出ER-图,并写出关系模式。依据ER图用SQL server创建和数据库相关表,视图,存放过程和触发器。系统功效要求基础实现对车辆,租赁用户查询。能够查询用户租赁历史统计。能够查看汽车价格、库存,能够查看汽车租借、归还、和费用。2.1.3揭示该数据库资源需求和设计约束2.2 需求分析2.2.1功效需求(1) 车辆管理 关键是表示管理员能够对租赁企业现有汽车具体信息进行管理,修改汽车基础信息,包含车牌号、汽车颜色、购入日期、类别及租赁状态等,也能够添加新购进来汽车基础信息,方便愈加快投入租赁市场,方便用户了解最新车辆信息和做出愈
8、加好租赁选择。(2)业务管理关键提供对汽车日常业务进行管理,如查询指定汽车租赁状态,被租赁车车牌号,所生成订单号,所租车种类,租车时间、归还时间及租赁金额,查询租车用户基础信息,方便于管理员愈加好管理车辆系统,保障系统安全性。三、 数据库环境说明数据库实例数据库系统数据库布署环境数据库设计工具数据库存放位置说明汽车租赁Sql server r2Windows 7Sql server r2Microsoft office visio E:sqlSQL实例用途说明四、 数据库命名规则3.1 数据库对象命名规则:数据库对象命名规则备注表英文命名比如:car汽车表存放过程proc_功效描述字符串比如:
9、proc_car汽车查询存放过程触发器功效命名比如:delete_car删除汽车视图View_功效描述字符串比如:view_rent查看租借信息表3.2 数据项编码规则: 数据项命名规则数据类型长度范围备注汽车编号所在地+字母号+数字Varchar类型10位租赁状态True or falseBit 类型订单号流水号Varchar类型10位用户号字母+数字编号Varchar类型10位工作人员编号数字Varchar类型10 位汽车类型号字母Varchar类型10位五、 逻辑设计5.1创建和数据库相关那部分实体关系图(ERD)、表及关系图表customersCusNo PYVarchar(10) N
10、OTNullCusNameVarchar(10) NOTNullCusSexVarchar(2) NOTNullCusAgeVarchar(4)NOTNullCusPhoneVarchar(10)CusCompanyVarchar(10)NOTNullCusIdentityVarchar(10)NOTNull表rentRecord PYVerchar(10)Not nullRentDatedateNot nullReturnDatedateNot nullCusNo Verchar(10)Not nullCarNo Verchar(10)Not nullRecordcostVerchar(10
11、0Not Null表carCarNo PYVerchar(10)Not nullCarColorVerchar(10)Not nullCarDatedateNot nullCarClassNo FYVerchar(10)Not nullCarStatebitNot null表carclassCarClassNo PYVerchar(10)Not nullCarClassCntVarchar(10)Not nullCarClassDayPriceVerchar(10)Not nullCarClassDayPriceExceedVerchar(100Not nullCarClassMonthPri
12、ce Verchar(10)Not nullCarClassSeat Verchar(10)Not null表workerWorkNo PYVerchar(10)Not nullWorkPassWordVerchar(10)Not nullWorkNameVerchar(10)Not nullWorkSexVerchar(2)Not nullWorkPhoneVerchar(10)表manageWorkNo PYVerchar(10)Not nullCarNo PYVerchar(10)Not null5.2创建数据库系统关系模型1.工作人员(工号、密码、姓名、性别、联络电话)2.用户信息(身
13、份证号、密码、姓名、性别、所在单位、联络电话)、3.车辆信息(车牌号、品牌、座位数、颜色、租赁状态、购入日期、分类号)4车辆类别(分类号、库存数、日租价格、日租超公里价格、月租价格、月租超公里价格、品牌)5.管理(工号、车牌号)备注:(工号和车牌号共同作为管理表主键,同时也是外键)6.租赁(订单号、身份证号、车牌号、租赁日期、归还日期、租赁总金额)六、 物理设计6.1表汇总表名功效说明car存放车辆信息carclass存放车辆类别信息rent存放租赁信息customers存放用户信息worker存放工作人员信息manage存放工作人员和车辆之间关系6.1.1表car:车辆信息表表名car数据库
14、用户Car_rent主键CarNo索引字段CarClassNo序号字段名称数据类型许可为空Y/N唯一Y/N区分度默认值约束条件/说明1CarNovarchar(10)NY高无主键2CarClassNovarchar(10)NN高无外键3CarStatebit(2)NN低00租赁状态4CardatedateNN低无购入日期5CarColorvarchar(10)NN低无汽车颜色sql脚本DROP TABLE IF EXISTS car;CREATE TABLE car ( CarNo varchar(10) NOT NULL, CarColor varchar(10) NOT NULL, Car
15、Date date NOT NULL, CarSta bit(10) NOT NULL, CarClassNo varchar(10) NOT NULL, PRIMARY KEY (CarNo), KEY CarClassNo (CarClassNo), CONSTRAINT CarClassNo FOREIGN KEY (CarClassNo) REFERENCES carclass (CarClassNo)6.1.2表carclass:车辆类别表表名carclass数据库用户Car_rent主键CarClassNo序号字段名称数据类型许可为空Y/N唯一Y/N区分度默认值约束条件/说明1Ca
16、rClassNovarchar(10)NY高无主键2CarClassCntvarchar(10)NN低无库存数3CarClassSeatbit(2)NN低无座位数4CarClassDayPrice2dateNN低无日租价格5CarClassDayPrice1varchar(10)NN低无日租超公里价格6CarClassMonthPricevarchar(10)NN低无月租价格7CarClassBrandvarchar(10)NN低无车辆品牌sql脚本DROP TABLE IF EXISTS carclass;CREATE TABLE carclass ( CarClassNo varchar(
17、10) NOT NULL, CarClassCnt varchar(10) NOT NULL, CarClassDayPrice1 varchar(10) NOT NULL, CarClassDayPrice2 varchar(10) NOT NULL, CarClassMonthPrice varchar(10) NOT NULL, CarClassBrand varchar(10) NOT NULL, CarClassseat varchar(10) NOT NULL, PRIMARY KEY (CarClassNo)6.1.3表customer:用户信息表表名customer数据库用户C
18、ar_rent主键CusNo序号字段名称数据类型许可为空Y/N唯一Y/N区分度默认值约束条件/说明1CusNovarchar(10)NY高无主键2CusPasswordvarchar(10)NN高无登录密码3CusNamevarchar(10)NN低无用户姓名4CusSexvarchar(10)NN低无用户性别5CusAgevarchar(10)NN低无用户年纪6CusPhonevarchar(10)NN低无用户电话7CusCompanyvarchar(10)NN低无企业sql脚本DROP TABLE IF EXISTS customer;CREATE TABLE customer ( Cus
19、No varchar(10) NOT NULL, CusName varchar(10) NOT NULL, CusSex varchar(2) NOT NULL, CusAge varchar(4) NOT NULL, CusPhone varchar(20) NOT NULL, CusCompany varchar(20) NOT NULL, CusPassword varchar(10) NOT NULL, PRIMARY KEY (CusNo)6.1.4表worker:工作人员信息表表名worker数据库用户Car_rent主键WorkNo序号字段名称数据类型许可为空Y/N唯一Y/N区
20、分度默认值约束条件/说明1WorkNovarchar(10)NY高无主键2WorkPasswordvarchar(10)NN低无密码3WorkNamevarchar(10)NN低无姓名4WorkSexvarchar(10)NN低无性别5WorkPhonevarchar(10)NN低无电话sql脚本DROP TABLE IF EXISTS worker1;CREATE TABLE worker1 ( WorkNo varchar(10) NOT NULL DEFAULT , WorkPassword varchar(10) DEFAULT NULL, WorkName varchar(10) D
21、EFAULT NULL, WorkSex varchar(10) DEFAULT NULL, WorkPhone varchar(10) DEFAULT NULL, PRIMARY KEY (WorkNo)6.1.5表rent:租赁表表名rent数据库用户Car_rent主键RecordNo索引CarNo、CusNo序号字段名称数据类型许可为空Y/N唯一Y/N区分度默认值约束条件/说明1RecordNovarchar(10)NY高无主键2CarNovarchar(10)NN高无外键3CusNovarchar(10)NN低无外键4RecordCostvarchar(10)NN低无总金额5Reco
22、rdRentDatevarchar(10)NN低无租赁时间6RecordReturnDatevarchar(10)NN低无归还时间sql脚本DROP TABLE IF EXISTS rent;CREATE TABLE rent ( RecordNo varchar(10) NOT NULL, RecordRentDate datetime NOT NULL, RecordReturnDate datetime NOT NULL, CusNo varchar(10) NOT NULL, CarNo varchar(10) NOT NULL, RecordCost varchar(10) DEFA
23、ULT NULL, PRIMARY KEY (RecordNo), KEY CusNo (CusNo), KEY CarNo (CarNo), CONSTRAINT CarNo FOREIGN KEY (CarNo) REFERENCES car (CarNo), CONSTRAINT CusNo FOREIGN KEY (CusNo) REFERENCES customer (CusNo)6.1.6表manage:管理表表名Wmanage数据库用户Car_rent主键CarNo、WorkNo索引CarNo序号字段名称数据类型许可为空Y/N唯一Y/N区分度默认值约束条件/说明1WorkNova
24、rchar(10)NY高无主键2CarNovarchar(10)NN高无主键sql脚本DROP TABLE IF EXISTS manege;CREATE TABLE manege ( WorkNo varchar(10) NOT NULL DEFAULT , CarNo varchar(10) NOT NULL DEFAULT , PRIMARY KEY (WorkNo,CarNo), KEY CarNo (CarNo), CONSTRAINT manege_ibfk_1 FOREIGN KEY (CarNo) REFERENCES car (CarNo), CONSTRAINT WorkN
25、o FOREIGN KEY (WorkNo) REFERENCES worker1 (WorkNo)6.2 存放过程6.2.1 查询每辆车状态和库存数关键代码use car_rentgoCREATE PROCEDURE proc_carasselect car.CarNo,car.CarState,carclass.CarClassCntfrom car,carclasswhere car.CarClassNo=carclass.CarClassNo6.2.2查询所输入用户账号租赁历史统计关键代码use car_rentgocreate procedure proc_customers(Cus
26、No varchar(10)asselect rent.Record,rent.RentData,rent.RetunDate,rent.RecordCost,rent.CusNo, car.CarNo,carclass.CarClassBrandfrom rent,car,carclasswhere CusNo=CusNo and rent.CarNo=car.CarNo and car.CarClassNo=carclass.CarClassNo; 实施exec proc_customers A016.2.3 查询输入用户账号租赁历史统计关键代码use car_rentgocreate p
27、rocedure proc_car_rent(CarNo varchar(10)asselect rent.Record,rent.RentData,rent.RetunDate,rent.CarNo,rent.CusNo,rent.RecordCostfrom rentwhere rent.CarNo=CarNo; 实施exec proc_car_rent 湘A88886.2.4 查询经过输入订单号查询订单信息关键代码use car_rentgocreate procedure proc_record(Record varchar(10)asselect rent.Record,rent.R
28、entData,rent.RetunDate,rent.CusNo,rent.RecordCostfrom rentwhere rent.Record=Record;实施exec proc_record 16.2.5经过输入类别统计汽车租赁金额和剩下库存数关键代码use car_rentgocreate procedure proc_carclassno(carclassno varchar(10)asselect carclass.CarClassDayPrice1,carclass.CarClassCntfrom carclasswhere carclass.CarClassNo=carc
29、lassno; 实施exec proc_carclassno A6.2.6 删除一辆车关键代码use car_rentgocreate procedure proc_delete_car(carno varchar(10)asdelete from carwhere car.CarNo=carno实施exec proc_delete_car 湘B88886.2.7 删除一条统计关键代码use car_rentgocreate procedure proc_delete_rent(record varchar(10)asdelete from rentwhere rent.Record=reco
30、rd实施exec proc_delete_rent 26.2.8还车(修改还车日期,默认没还车前,还车日期等于借车日期,只有当没还过车时候才能修改还车日期)关键代码use car_rentgocreate procedure proc_return_car(record varchar(10), returndate date)asupdate rentset RetunDate=returndatewherereturndaterent.RetunDateand DATEDIFF(DAY,rent.RentData,rent.RetunDate)=0实施exec proc_return_ca
31、r 1,-8-176.3触发器6.3.1输入新车牌号及信息,此车辆所对应车辆类别库存数自动增加关键代码use car_rentgoCreate Trigger add_newcar On car after insert As UPDATE carclassSET CarClassCnt=CarClassCnt+1WHERE carclass.CarClassNo IN (SELECT CarClassNo from INSERTED i) GO6.3.2删除车牌号及信息,此车辆所对应车辆类别库存数自动降低关键代码use car_rentgoCreate Trigger delete_car
32、On car after delete As UPDATE carclassSET CarClassCnt=CarClassCnt-1WHERE carclass.CarClassNo IN (SELECT CarClassNo from deleted i) GO6.3.3 :当产生一个新订单时,订单中所预订车辆所对应车辆类别库存数自动降低。(借车时)关键代码use car_rentgoCreate Trigger rent_car On rent after insert As UPDATE carclassSET CarClassCnt=CarClassCnt-1where CarCla
33、ssNo in(select CarClassNo from car where CarNo in (select CarNo from rent where CarNo in (select CarNo from inserted )GO6.3.4修改订单还车日期时时,订单中所预订车辆所对应车辆类别库存数自动增加。(还车时)关键代码use car_rentgoCreate Trigger return_car On rent after update As UPDATE carclassSET CarClassCnt=CarClassCnt+1where CarClassNo in (sel
34、ect CarClassNo from car where CarNo in (select CarNo from deleted )Go6.3.5当产取消一个订单时,订单中所预订车辆所对应车辆类别库存数自动增加关键代码use car_rentgoCreate Trigger delete_rent_car On rent after delete As UPDATE carclassSET CarClassCnt=CarClassCnt+1where CarClassNo in(select CarClassNo from car where CarNo in (select CarNo f
35、rom deleted where car.CarState=false)GO6.3.6当产生一个新订单时,订单中所预订车辆租赁状态由空闲状态(ture)变为预订状态(false)(借车时)关键代码use car_rentgoCreate Trigger rent_state_car On rent after insert As update carset CarState=falsewhere CarNo in(select CarNo from rent where CarNo in (select CarNo from inserted );GO6.3.7改订单还车日期时时,订单中所预
36、订车辆租赁状态由预订状态(false)变为空闲状态(ture)。(还车时)关键代码use car_rentgoCreate Trigger return_state_car On rent after update As UPDATE carset CarState=truewhere CarClassNo in (select CarClassNo from car where CarNo in (select CarNo from deleted )Go6.3.8当取消一个新订单时,订单中所预订车辆租赁状态由空闲状态(false)变为预订状态(ture)关键代码use car_rentgoCreate Trigger delete_rent_state_car On rent after delete As update carset CarState=truewhere CarNo in (select CarNo from deleted where car.CarState=false );GO6.3.9修改订单还车日期时时,更新实际花费。(还车时)关键代码use car_rentgoCreate Trigger return_car_price On rent a