《基于UML的汽车租赁管理系统设计含源文件.pdf》由会员分享,可在线阅读,更多相关《基于UML的汽车租赁管理系统设计含源文件.pdf(26页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、.-基于 UML 的汽车租赁管理系统设计1问题描述11 需求描述随着汽车工业的发展和汽车的普及,汽车租赁成为近年来兴起的一个新行业。使用汽车租赁管理系统可以规企业的管理和经营行为,减少企业的经营成本,提高工作效率。针对以上的要求,汽车租赁管理系统的用户是汽车租赁企业的管理人员,其需求功能应包括汽车类型管理、会员类型管理、保险类型管理、销售商管理、保险公司管理、客户信息管理、会员信息管理和汽车租赁、续租、归还管理等主要功能,从而可以形成统一有效的管理。在该系统中,要实现对汽车类型信息、会员类型信息和保险类型信息等基本信息的添加、修改、删除、和查询;销售商信息的添加、修改、删除和查询;保险公司信息
2、的添加、修改、删除和查询;客户信息和会员信息的添加、修改、删除和查询以及汽车租赁、续租、归还等具体操作的实现。以满足当前该行业在处理业务上的需求。12 运行环境描述本系统采用的是 C/S 体系结构风格,对系统息的查询、修改、删除和添加等操作都是对数据库的操作,在数据库服务器上实现的,而在本系统中运行的界面只是客户应用程序,负责提供管理人员与数据库交互的界面,向数据库服务器提交用户请求并接受来自数据库服务器的消息,。而数据库服务器也就是后台程序,主要是负责有效的管理系统的数据库资源,对客户应用程序传来的信息加以处理,对数据库的信息进行操作。系统开发采用 Rational Rose 进行统模,编程
3、语言是 Microsoft Visual Basic,数据库设计采用的是 Microsoft Access 2000,在 Windows Xp 操作系统下测试并运行。13 系统性能描述Microsoft Visual Basic 与其他开发工具相比,具有简单易学、灵活方便和易于扩充等特点,越来越多地被用做客户/服务器应用程序的前端开发工具,与后台的 Microsoft Access2000 数据库相结合,能够提供高性能的管理信息系统解决方案。-可修编-.-2 用例模型及分析类图的描述21 用例模型描述本系统中,以汽车租赁为实现功能,其他的功能都是为了服务于该主要功能,从而便于管理。系统的用例图
4、如图 2-1 所示。-可修编-.-会员类型管理保险类型管理汽车类型管理销售商管理保险公司管理客户信息管理基本信息管理会员信息管理客户会员管理汽车信息管理租赁业务管理管理人员汽车租赁管理汽车续租管理系统用户管理汽车归还管理客户修改自身密码图 2-1 汽车租赁系统用例图通过对系统进行需求分析,得到系统的用例图,从而知道了系统要实现的基本功能。客户通过管理人员对系统进行操作,通过建立用例图得知系统的体系结构。本系统采用 3层结构设计,即程序逻辑结构分为用户界面层、业务逻辑处理层和数据存储层。系统中将-可修编-.-用户、汽车管理等都封装成相应的类,同时每个类都有自己对应的操作类,从而再次提高了对数据库
5、操作的安全性和程序的可扩展性。在系统中,只有管理人员才有权限使用本系统,才能对数据库进行操作。(1)管理人员对基本信息的管理,包括对汽车类型信息的增加、删除、修改和查询;对会员类型信息的增加、删除、修改和查询;保险类型信息的增加、删除、修改和查询;销售商信息的增加、删除、修改和查询;保险公司信息的增加、删除、修改和查询。所以,有基本信息管理用例,还包括汽车类型管理用例、会员类型管理用例、保险类型管理用例、销售商管理用例和保险公司管理用例。(2)管理人员对客户会员的管理,主要是会员类型的修改和查询,客户信息的增加、删除、修改和查询。所以,有客户会员管理用例和客户信息管理用例。(3)管理人员对租赁
6、业务的管理,包括汽车类型信息的增加、删除、修改和查询;汽车租赁信息的增加、删除、修改和查询;汽车续租信息的增加、删除、修改和查询;汽车归还信息的增加、删除、修改和查询;所以,有租赁业务用例、汽车租赁管理用例、汽车续租管理用例、汽车归还管理用例。(4)管理人员对系统用户的管理,包括系统用户的增加、删除、修改和查询和密码的修改;所以有系统用户管理用例和密码修改用例。分析系统的使用对象和用户需求,设计系统的体系结构。系统的功能模块如图 2-2 所示。-可修编-.-汽车租赁管理系统基本信息管理客户会员管理租赁业务管理系统用户管理汽车类型管理会员类型管理保险类型管理销售商管理保险公司管理客户信息管理会员
7、信息管理汽车信息管理汽车租赁管理汽车续租管理汽车归还管理系统用户管理修改自身密码图 2-2 汽车租赁管理系统功能模块示意图22 分析类图描述在系统中,应该包括“基本类型信息”类,“会员类型信息”类,“公司信息”类,“客户信息”类,“汽车信息”类,“汽车租赁信息”类,“管理员信息”类。如图 2-3 即为汽车租赁管理系统类图。-可修编-.-图 2-3 汽车租赁管理系统类图系统管理员是“Users”类的子类,它与客户是多对应一的关系,客户通过系统管理员办理业务,而使用本系统;客户与租赁是一对应多的关系,一个客户可以租赁多辆汽车,而汽车与租赁是一一对应的;每个客户可以有会员类型也可以没有,所以是一对应
8、多的关系;每辆汽车都有其销售商,而销售商可以销售多辆汽车,所以汽车和销售商是多对一的关系;同样每辆汽车都有其对应的保险类型,所以与保险类型是多对一的关系。3详细设计描述-可修编-.-31 核心时序图描述311 汽车信息管理时序图图 3-1 汽车信息管理时序图312 修改密码时序图-可修编-.-图 3-2 修改密码时序图313 汽车租赁管理时序图图 3-3 汽车租赁管理时序图314 汽车续租管理时序图-可修编-.-图 3-4 汽车续租时序图315 汽车归还时序图图 3-5 汽车归还时序图32 状态图描述321 汽车信息管理状态图-可修编-.-图 3-6 汽车信息管理状态图322 修改密码状态图图
9、 3-7 修改密码状态图323 汽车租赁管理状态图-可修编-.-图 3-8 汽车租赁管理状态图324 汽车续租管理状态图图 3-9 汽车续租管理状态图325 汽车归还管理状态图-可修编-.-图 3-10 汽车归还管理状态图33 组件图描述-可修编-.-图 3-11 组件图4编程设计描述41 信息代码设计和数据库设计用户的需求具体体现在各种信息的提供、保存、更新和查询上,这就要求数据库结构能充分满足各种信息的输出和输入。收集基本数据、数据结构以及处理数据的流程,组成一份详尽的数据字典,为以后的具体设计打下基础。经过上述系统功能分析和需求总结,考虑到将来功能上的扩展,设计如下面所示的数据项和数据结
10、构:(1)用户信息,包括数据项:用户名、密码。(2)类型信息,包括数据项:类型 ID、类型名称、描述等。(3)会员类型,包括数据项:会员 ID、会员类型、享受折扣等。-可修编-.-(4)公司信息,包括数据项:公司名称、联系、电子、地址等。(5)客户信息,包括数据项:客户 ID、驾驶证号、驾龄等。(6)汽车信息,包括数据项:车牌号、购买日期、押金、日租金等。(7)汽车租赁信息,包括数据项:合同 ID、车牌号、客户 ID、租赁时间等。数据库中包含了 7 个表,即基本类型表 Types、会员类型表 MemberType、公司信息表pany、客户信息表Customer、汽车信息表Cars、汽车租赁表L
11、ease 和用户信息表 Users。表4-1 表 Types 的结构编号1234表 4-2 表 MemberType 的结构编号123表 4-3 表 pany 的结构编号12345678字段名称IdpanyTelephoneAddressEmainContactTypeIdment数据类型IntVarchar 100Varchar 50Varchar 50Varchar 50Varchar 50TinyintVarchar 200说明公司编号,主键,自动增 1公司名称联系地址电子联系人公司类型,1-销售商,2-保险公司说明字段名称IdTypeNameRate数据类型IntVarchar 50F
12、loat说明类型编号,主键,自动增 1类型名称享受的折扣字段名称IdTypeNameTypeIdDescription数据类型intVarchar 50TinyintVarchar 100说明类型编号,主键,自动增 1类型名称类型分类,1-汽车类型,2-保险类型类型描述-可修编-.-表 4-4 表 Customer 的结构编号1234567891011121314151617181920表 4-5 表 Cars 的结构编号123字段名称CarNoTypeIdCarName数据类型Varchar 20IntVarchar 50说明车牌号,主键汽车类型汽车名称字段名称IdNameSexAgeIdC
13、ardTelephoneWorkorgAddressZipCodeEnailLicenseNoLicenseTypeGetDateExpiredDateDriverAgeFlagTypeIdCertificateWarrantorWidCard数据类型Varchar 20Varchar 50Char 2TingintVarchar 30Varchar 30Varchar 50Varchar 50Varchar 10Varchar 30Varchar 30Varchar 20Varchar 20Varchar 20TinyintTingintIntVarchar 40Varchar 50Vara
14、char 30说明客户编号,主键性别年龄号工作地点家庭地址邮政编码电子驾驶证号驾驶证类型发证日期到期日期驾龄会员标记(0-非会员,2-会员)会员类型抵押证件担保人担保人号-可修编-.-4567891011121314151617181920212223ColorEngineNoCarCaseSaleIdBuyDateInsurNoInsurIdInsurTypeInsurSateInsurEdateDepositDayPriceWeekPriceMonthPriceWeekEndPriceDayPMOverTimePriceOverKMPriceStatusmentVarchar 20Varc
15、har 50Varchar 50IntDatetimeVarchar 50IntVarchar 50DatetimeDatetimeIntIntIntIntIntIntIntIntChar 10Varchar 200汽车颜色发动机号车架号销售商编号购买日期保单号保险公司编号保险种类起保日期结束日期押金日租金周租金月租金周末租金日限公里数超时租金超公里租金状态备注表 4-6 表 Lease 的结构编号12345字段名称ContractNoCarNoCustIdLeaseTimeLeaseMode数据类型Varchar 50Varchar 20Varchar 20DatetimeChar 10说明
16、合同编号,主键车牌号客户编号租赁时间租赁模式(分为按日、周和月)-可修编-.-6789101112131415161718192021222324Price1Price2WorkDaysWeekEndCountDepositDayKmOutKMOPrice1OPrice2ReturnTimeReturnKMOtherCostRatePaymentTotalStatusCreateDateUserNameRealRTimeIntIntIntIntIntIntIntIntIntIntIntIntFloatIntIntChar 10DatetimeVarchar 20Datetime租赁价格按日租赁
17、时的周末租赁价格租赁工作日、周、月的数量租赁周末个数押金日限公里数出车公里数超公里每公里价格超时每小时价格应归还时间归还公里数其他费用折扣实际支付金额总金额状态,必填字段(是)创建日期创建人实际归还日期表 4-7 表 Users 的结构编号12表 4-8 表的外键定义关系名FK_Cars_Types主键表Types主键字段Id外键表Cars外键字段TypeId字段名称UserNameUserPwd数据类型Varchar 50Varchar 50说明用户名,主键密码-可修编-.-FK_Cars_panyFK_Cars_pany1FK_Customer_MemberTypeFK_Lease_Car
18、sFK_Lease_CustomerpanypanyMemberTypeCarsCustomerIdIdIdCarNoIdCarsCarsCustomerLeaseLeaseSaleIdInsurIdtypeIdCarNoCustId43 输入设计在本系统中,使用的语言是 Microsoft Visual Basic,界面设计比较方便,从而对于输入,主要是在窗口中的各种文本框、文本区和其他的控件来实现用户的输入,程序接受从这些控件来的信息,执行相应的操作。对于本系统输入设计,由于界面的设计容易,从而其实现输入的方式也简单明了。这也是本系统优点之一。44 输出设计和输入设计相似,系统的输出设计是
19、通过窗口中的各种文本框、文本区和弹出对话框等控件来实现结果的输出。5 用户界面设计和处理过程的设计的描述51 用户界面设计描述511 系统用户登录窗体图 5-1 系统登录界面登录窗体的名称为 FrmLogin,它的界面布局如图5-1。用户正确登录后,就会进入主界面。512 系统主界面-可修编-.-主窗体是工程的启动对象,可以在系统菜单中选择适当的命令,打开属性窗口设置启动对象。本系统中主窗体名为 FrmMain。如图 5-2。图 5-2 系统主界面在主界面,用户可以进行基本信息管理、客户会员管理、日常业务管理以及系统用户管理。通过单击对应的菜单选项可以方便快捷地转到本系统功能模块。513 汽车
20、租赁管理窗体-可修编-.-图 5-3 汽车租赁管理界面514 汽车归还管理窗体图 5-4 汽车归还管理界面515 汽车归还结算窗体-可修编-.-图 5-5 汽车归还结算管理516 汽车租赁信息添加管理-可修编-.-图 5-6 汽车租赁信息添加52 处理过程设计描述521 类型管理模块设计类型管理模块包括以下功能:(1)类型信息编辑。(2)类型信息管理。(3)选择类型信息。汽车类型管理信息编辑的窗体可以用来添加和修改类型信息,窗体名为 FrmTypeEdit,它的窗体属性与登录窗体相似。汽车类型信息管理窗体的名称为 FrmType,它包括三个过程,DataRefresh 过程的功能是根据种类编号
21、显示列表中的信息;当用户在“汽车类型”和“保险类型”单选按钮之间切换是,触发 OptSel_Click 事件;当用户单击“修改”按钮时,触发Cmd_Modi_Click 事件。522 汽车租赁管理模块设计汽车租赁管理模块包括以下功能:(1)汽车租赁信息管理,其窗体名为 FrmLeaseEdit,窗体中使用 3 个 ADODC 控件分别为汽-可修编-.-车信息、租赁价格和客户信息表格提供数据源。当用户单击“查找”按钮时,触发Cmd_SchMember_Click 事件;当用户更换租赁模式时,触发cob_Mode_Click 事件,重新计算租赁总费用金额和归还时间。(2)汽车续租管理,其窗体名为
22、FrmLeaseAddEdit,在汽车的续租过程中,续租的各种价格继续使用租赁是的价格,不能更改,租赁模式也不允许更改。如果要更改租赁模式,只能归还汽车后重新办理租赁手续。在租赁中,只允许更改租赁的日(周、月),同时系统自动重新计算租赁总费用和应还时间。(3)汽车租赁管理,其窗体名为 FrmLease。它的GridRefresh 过程用来更新 ADODC 控件的记录源,从而更新 DataGrid 控件中显示的美容。6给出软件的测试方法和测试结果61 软件测试方法在本系统中,主要采用的是功能性测试,其中所使用的用例包括了边界值分、最坏情况分析、特殊值测试、输入输出等价类等测试方法。是在已知系统的
23、功能要求上,对系统所能实现的功能进行测试,看是否满足需求。62 测试用例和测试结果621 用户名和密码输入有误时测试用例:用户名为:ccqjs,密码为:123456测试结果为:图 6-1图 6-1 登录出错622 汽车租赁操作测试用例为:车牌为:京 AS1111,客户编号为:C001,合同编号为:886,周数为:5-可修编-.-测试结果为:在归还管理界面中有可以归还的汽车,且合同号是:886,车牌号:是图京AS11116-2,客户号是:C001。结果如图 6-2图 6-2 汽车租赁测试623 汽车归还操作测试用例为:车牌为:京 AS1111,客户编号为:C001,合同编号为:886测试结果为:
24、数据库中没有车牌为京 AS1111 的汽车信息,如图 6-3图 6-3 汽车归还测试624 汽车管理添加操作-可修编-.-测试用例为:车牌号为:鄂 AS123;车名为:name;分类为:夏利 2000 等测试结果:在数据库中有该记录,如图 6-4 所示图 6-4 添加汽车信息7总结心得71 设计特点首先,本系统设计所采用的是 3 层结构设计,即程序逻辑结构分为用户界面层、业务逻辑处理层和数据存储层。这 3 层的设计,使得该系统的运行性能较单纯的 c/s 模式有了很大的提高,而且所设计的界面逻辑结构清晰,便于进行修改和添加新的功能。其次,本系统在界面设计上都采用了模块化的处理思想,把很多界面共有
25、部分集成为一个模块,充分显示了 vb 面向对象程序语言的强大用途。在程序结构上,所有的模块都分得很清晰,各个窗体所实现的功能都很明了,而且对数据库的操作也是通过对象来实现的。将系统中各个模块的分工分得很明确,使得各个模块之间的功能相对比较独立,但在系统层次上则是联系很紧密的。最后,本系统将数据库中的表建成类,并在类中定义了对类的基本操作,使得在以后在过程的使用中,不必重新定义对类的对象的操作,而且实现起来也是比较方便的,出错的机会也会降低。在这点上,充分体现了面向对象的设计方法。本系统的功能实际上是比较完善的,需求做得比较细致,而且查阅了很多资料,涉及-可修编-.-的围也比较广泛。72 设计不
26、足首先,在本系统的设计设计过程中,由于学习和考试的原因,耽误了一个星期,所以做起来的程序是比较匆促的,虽然需求相对来说还好,但是系统实现上出现了一些小问题,有些功能实现得不是很好,有待于进一步的提高。其次,由于这次为了方便设计界面,所选取的编程语言也是没什么难度,以至于失去了课程设计所要达到的要求。在编程过程中,遇到最大的问题就是与数据库的连接问题,以及数据库中表的增加、删除、修改和查询等操作。在后来查阅相关资料才明白具体的细节。没了解这门语言就用这门语言做课程设计,这是盲目的,直接导致的就是后续编程过程中漏洞百出,检查起来也很困难。最后,这次还是没太重视这个课程设计,在心态方面就不行,一直也
27、没有全力以付,虽然也学到了东西,但是相对来说,是教训大于所得。这一点在即将来临的毕业设计中得好好的克服,在毕业设计中一定得稳扎稳打,好好完成在大学期间的最后一个课程设计。8 参考文献1友生,软件体系结构,:清华大学,2004 年 1 月2火旺、春林等,程序设计语言编译原理(第 3 版),国防工业,2003 年 2 月3开英,数据库系统概论,理工大学,2003 年 1 月4王少锋,面向对象技术 UML 教程,清华大学,2004 年 2 月5文耘等译,需求工程,机械工业,2003 年 8 月6王珊,数据库系统简明教程,高等教育,2004 年 9 月7余雪丽,软件体系结构及实例分析,科学,2004 年 10 月8王智学,ROSE 对象建模方法与技术,机械工业,2003 年 7 月9阿奇,Visual Basic 使用教程(第二版),电子工业,2004 年 1 月-可修编-