- 1、本文档共15页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
石家庄经济学院
课程设计报告
课程名称: 火车订票系统的设计与实现
专 业: 计算机技术与科学
姓 名:
班 级:
学 号:
2013年 6 月 23 日
火车订票系统
一、需求分析
1.现如今随着节假日出游人数的增多,带来了很多问题,如:买票排队、和排队买不上票的问题。给人们的出行带来了很大的不变。基于上面种种原因,我们结合这次课设内容。开发出一下火车网上订票系统的方案
2.需求分析:火车网上订票系统应有的主要功能有:
(1)登录:根据自己的姓名和身份证号进行登录操作。
(2)查询:根据自己想去的目的地,查询火车票剩余量和价钱、发车时间等信息。
(3)订票:根据查询出的结果选着订票的种类:如学生票、军人票、记者票等信息。
(4)退票:根据火车票号可以进行退票等操作。
(5)管理:系统管理员可以对系统的各种信息进行管理操作。
二、概要设计
根据功能需求,设计系统的总体结构,火车订票系统功能模块图;如图所示
图 1系统模块图
各功能模块实现的功能:
车票模块:可以完成对车票的订票退票改签等操作。
查询模块:完成对各种信息的查询
用户登录模块:完成用户登录的验证
管理员模块:对整个系统的维护和管理
三、数据库设计
1.概念结构设计
E-R图
(1)实体及属性
图 2用户E-R图
图 3 列车E-R图
图4车站E-R图
图5 车票种类E-R图
图6 火车种类E-R图
图7 座位种类E-R图
图8 管理员E-R图
图9 经过站E-R图
图10 车票E-R图
图11 总体E-R图
2.逻辑结构设计
(1)ER图向关系模式的转换
1) 一个实体型转换为一个关系模式,实体的属性就是关系的属性,实体的键就是关系的键。
用户、管理员、车站、列车、列车类型、座位类型、车票类型、车票、经过站个转换为关系模式。
用户(姓名,身份证号,生日,地址,性别,电话)
管理员(姓名,身份证号,工号,密码,性别,工作地点)
车站(车站编号,车站名,占地面积,最大容人量,交通信息,通过车辆)
列车(车次,类型号,始发站号,终点站号,始发时间,末站时间,路线,软座数量,硬座数量)始发站,和终点站 都是外码 参照与车站的车站编号
列车类型(类型编号,类型名称,收费标准)
座位类型(类型编号,类型名称,收费标准)
车票类型(类型编号,类型名称,收费标准)
车票(票号,车次,始发站号,末站号,车票类型,价格,座位号,发车时间,持票者姓名,)始发站号,末站号,车票类型,为外键参照于车站编号,车票类型。
2) 一个实体的联系转换为关系模式时,应首先确定该联系的类型,再确定相应的键:经过站(车次,车站编号,到站时间,出站时间,硬座剩余,卧铺剩余,行程距离)使用了联合主键
3.数据库物理设计
由于查询的时候用到的表过多,所以创建视图方便查询。
建立了3个视图
Traininfo(车次,类型名,始发站,终点站,始发时间,尾站时间,路线,软座数量,硬座数量)来自 列车 、车站、列车类型3个关系模式
Gobyinfo(车次,车站名,到站时间,出站时间,硬座剩余,卧铺剩余,行程距离)来自。列车 和 车站2个关系模式
Ticketinfo(票号,车次,始发站,末站,车票类型名,价格,座位号,发车时间,持票者姓名,座位类型)来自 经过站,车站,车票分类,座位类型,和车票5个关系模型。
3.数据库物理设计
图12 admin表结构
图13goby表
图14policeinfo表
图15seattype表
图16station表
图 17ticket表
图18tickettype表
图19train表
图20traintype表
图21gobyinfo视图
图22ticketinfo视图
图23traininfo视图
四、详细设计
1.数据库的实施
本系统使用的是mysql数据库。因为他提供了很丰富的java编程驱动接口。用java
可以很直接方便的来操作数据库。创建了9个表和3个视图如图所示
图24全部表和视图
由于mysql 5.1才开始支持视图,但是他把视图做为一种虚拟表来处理的。所以在show tables 命令时 会把 表和视图一起显示出来。
由于开发是使用的ssh然后连接数据库直接配置xml文件即可。
2具体模块所涉及到的主要算法
图25登录流程图
查询信息。可以根据选着的车站或车次进行查询座位剩余量等信息。
图26 查询流程图
票价按着铁道部的公布的信息计算其明细如下:
票价组成客票价包括三部分:基本客票票
文档评论(0)