航空客票系统数据库设计与功能模块开发

5星 · 超过95%的资源 需积分: 50 10 下载量 66 浏览量 更新于2024-10-04 1 收藏 202KB DOC 举报
本课程设计报告是关于一个基于数据库的飞机订票系统,旨在模拟航空客运订票业务中的各项操作,如查询航班、订票、退票等。系统设计的目标是利用Microsoft SQL Server 2000作为后台数据库,实现数据的增删改查功能。以下是该系统的主要组成部分和数据库设计: 1. **问题描述与要求** - 航空客订票系统需要包括航班信息管理模块,记录航班号、起飞时间和降落时间、城市、票价、折扣以及准载人数等详细信息。 - 订票功能模块涉及输入航班号、订票日期、乘客信息以及票数,将这些数据存储在订票信息表中。 - 查看航班和订票信息模块分别用于展示所有航线和已预订的票务详情。 - 查询模块支持按航班号或到达地点搜索航班信息。 - 退票功能允许用户取消不满意预订的机票。 - 系统还包括一个信息管理模块,允许管理员更新航班信息。 - 安全性方面,设置登陆界面,使用管理员账号和密码管理系统权限。 2. **系统分析** - 数据库概念结构设计:系统包含航班信息(Flight)、订票信息(Book)、退票信息(Tuipiao)和用户信息(admin)等抽象数据类型,这些数据被组织在四个顺序表中。设计强调了层次关系和清晰的操作流程,比如首先加载文件信息,然后根据用户输入的账号执行相应操作并保存结果。 3. **数据库设计** - E-R图展示了系统的概念模型,包括五个实体关系模型: - **图3-1**:航班信息表,包含了航班的基本信息,如航班号、起降时间、城市和票价等。 - **图3-2**:订票信息表,记录了乘客的订票行为,包含航班号、订票日期、乘客信息和票数。 - **图3-3**:退票信息表,用于跟踪和管理已退票的订单。 - **图3-4**:用户信息表,用于存储管理员的账号和密码,确保系统安全。 - **图3-5**:未提及,可能是管理员账户表,用于管理系统的登录权限。 通过这些E-R图,可以建立出完整的数据库结构,便于后续的数据库设计、编码和测试。系统设计充分考虑了实际航空业务的需求,提供了一种实用且可扩展的机票预订解决方案。
2013-02-16 上传
#这只是一个半成品,只是实现了,一个完整的订票过程,对于,如果刷票,自己研究 #简单过程 # 第一、getRandAndCookie() 获得cook 和一个随机数用于登录 # 第二、getEnterRandCode() 得到登录时的识别码 # 第三、setuseandpassword(randcode,use,password) 发送随机数、识别码和用户及密码。由于随机数只在内部使用,所以定义成了全局变量, # 第四、GetTrainList() 得到所有车站列表,'@bjb|北京北|VAP|beijingbei|bjb|0' 其中有中文、拼音、拼音缩写、所一个ID(唯一),其主要是可以,通过上面的列表,找到它的唯一ID,TranCityToId('南昌') # 第五、GetTrainNumList(date,fromstationid,tostationid,starttime) 得到哪到哪的所在车次,消息格式如下,其中所以,一下车次的的ID:"id":"650000K1060I" # {"end_station_name":"北京西","end_time":"16:18","id":"650000K1060I","start_station_name":"深圳","start_time":"10:54","value":"K106"} # 通过ChangeToTrainNumId('K106')得到车次ID # 第六、QueryTrain(fromstationid,tostationid,date,stationNum,starttime) 就是点击查询按键,得到是否有能预订,格式如下 #       南昌         20:12,    北京西        07:38,11:26,--,--,--,--,10,有,有,--,有,有,--,<a name='btn130_2' class='btn130_2' # 通过choiceSubmitNum(stationNum,trainsubmitinfo)提取出getSelected()消息 # 第七、submitRequest(choiceSubmitNum(stationNum,trainsubmitinfo),date,starttime) 就是点击预订按钮 # 第八、getrandCheckCode()得到提交订单的识别码 # 第十、CheckInMyTicket(info,randcode,peoples)点击提交,如果成功的话,就会返回{"errMsg":"Y"} # 出于,网络是UTF8格式,所以,必须# -*- coding: utf-8 -*-,(当然,自己转换也是可以的) # 出于这一个控制台信息,所以,识别码的图片在脚本同一目录 #得到头信息