课程设计飞机订票系统课件

上传人:bin****86 文档编号:53667185 上传时间:2018-09-03 格式:DOC 页数:21 大小:355.50KB
返回 下载 相关 举报
课程设计飞机订票系统课件_第1页
第1页 / 共21页
课程设计飞机订票系统课件_第2页
第2页 / 共21页
课程设计飞机订票系统课件_第3页
第3页 / 共21页
课程设计飞机订票系统课件_第4页
第4页 / 共21页
课程设计飞机订票系统课件_第5页
第5页 / 共21页
点击查看更多>>
资源描述

《课程设计飞机订票系统课件》由会员分享,可在线阅读,更多相关《课程设计飞机订票系统课件(21页珍藏版)》请在金锄头文库上搜索。

1、1数据库课程设计数据库课程设计题题 目目 _飞机订票系统飞机订票系统_ _ _学学 院院 计算机学院计算机学院 专专 业业 计算机科学与技术计算机科学与技术 年级班别年级班别 学学 号号 学生姓名学生姓名 指导教师指导教师 左亚尧左亚尧 2013 年年 1 月月 15 日日2目目 录录一、需求分一、需求分3析析.1二、系统设二、系统设计计.3三、详细设计三、详细设计6四、课程设计总四、课程设计总结结16五、参考文五、参考文献献16六、附六、附录录164一、需求分析一、需求分析(一)系统综合需求航空订票管理系统主要是为机场、航空公司和客户三方服务。航空公司提供航线和飞机的资料,机场则对在本机场起

2、飞和降落的航班和机票进行管理,5而客户能得到的服务应该有查询航班路线和剩余票数,以及网上订票等功能。客户可以分为两类:一类是普通客户,对于普通客户只有普通的查询功能和订票功能没有相应的票价优惠;另一类是经常旅客,需要办理注册手续,但增加了里程积分功能和积分优惠政策。机场还要有紧急应对措施,在航班出现延误时,要发送相应的信息。(二)系统功能航班查询航班查询:根据用户输入的“起飞机场” 和“降落机场”信息找到符合要求的航班号,并显示相应的起飞时间、飞行里程、各舱等的余票情况、各舱等的票价情况。供用户进行选择。订票订票: 根据用户输入的“所订航班号”和“订票乘客信息”,为用户查看该航班是否有余票:有

3、则生成一条新的票务信息,根据该用户的积分情况制定票价,修改其积分里程;若已无余票,则将该乘客登机在侯票名单之中。退票退票:根据用户输入的“所退票流水号”信息,修改订票乘客的积分信息,将相关的票务记录删除;并在侯票记录中找到符合航班要求的第一名乘客,为其办理订票服务,相关的修改其积分。售票情况统计售票情况统计:统计每个航班的各个舱位等级的已售票数目,侯票数目。积分功能积分功能:为每一个已订购的乘客记录其飞行里程积分,当积分达到一定程度后,为其提供打折的票价。航班延误航班延误:当要延误一个航班时,找到已订购该航班的乘客,发送提示信息。2数据字典该软件的数据库由下述四张数据表组成:61、航空公司:

4、Company 字段字段名类型宽度说明1company_name varchar20航空公司2phone varchar15公司电话2、飞机信息:Plane 字段字段名类型宽度说明1plane_number varchar1.0飞机编号2plane_type varchar20飞机类型3quota_f int 头等舱定额数,4quota_s int普通舱定额数5company_namevarchar20所属公司3、航线信息 Line 字段字段名类型宽度说明1line_numbervarchar10航线号码2airport_s varchar20起飞地点3airport_evarchar20起飞

5、终点4distance int距离5company_namevarchar20所属公司4、航班信息: Flight 字段字段名类型宽度说明1flight_numbervarchar10航班信息2plane_number varchar10飞机号3line_number varchar10航线4price_f int头等舱价格5price_sint普通舱价格6flydate varchar20飞行日期5、客户信息 : Passenger 7字段字段名类型宽度说明1passenger_namevarchar10客户名2distancesint积分3E_mail varchar20邮箱6、订票信息

6、:Ticket 字段字段名类型宽度说明1ticket_numberint票号 (自动增一)2flight_number varchar10航班号3passenger_name varchar10乘客名4cabin varchar头等舱还是普通 舱5payint价格6、候选票信息 : Wait 字段字段名类型宽度说明1passenger_namevarchar乘客名2flight_number varchar10航班号3cabin varchar头等舱还是普通 舱4E_mail varchar10邮箱三、系统设计三、系统设计(一)数据库概念设计(一)数据库概念设计E-R 图如下:8(二)数据库逻

7、辑设计(二)数据库逻辑设计 将数据库的概念模型转换为关系模型: 航空公司表:(公司名称,公司电话) ;飞机表:(飞机号, 机型, 头等舱定额数, 普通舱定额数, 所属航空公司) ;航线表:(航线号, 起飞机场, 降落机场, 飞行里程, 所属航空公司) ;航班表:(航班号, 执行飞机号, 所飞航线号, 头等舱票价, 普通舱票价,起飞时间) ;乘客表:(乘客姓名, 里程积分, E_mail) ;机票表:(机票流水号, 所乘航班号,订票乘客姓名, 所乘舱位等级, 票价) ;侯票表:(所侯航班, 侯票乘客姓名, 所需舱位等级, 乘客 E_mail) ;9(三)数据库与数据表设计(三)数据库与数据表设计

8、 物理结构设计物理结构设计 在 SQL 数据库中需要建立 3 个数据表:表、部门信息数据表和工资数据表。 1.数据库与数据表设计数据库与数据表设计companyFlight LinePassengerPlane10Ticket Wait 2.数据完整性设计数据完整性设计 1) 给每个表实施主键约束。 主键图中 PK 2)实施 CHECK 约束 全部 not null 3)外键约束外键途中 FK 4)惟一约束 每个表的主键需定义为惟一性:5) 强制约束6)规则 cabin 约束为 (cabin = 头等舱 or cabin = 普通舱)两种类型。四、详细设计四、详细设计(一)建数据库(一)建数据

9、库CREATE DATABASE PLANE_DB ON PRIMARY( NAME=PLANE_DB , FILENAME=D:PLANE_DB .mdf, SIZE=4MB, MAXSIZE=6MB, FILEGROWTH=2MB11) LOG ON (NAME =PLANE_DB _log, FILENAME =D:PLANE_DB .ldf,SIZE=1MB,MAXSIZE=25MB,FILEGROWTH=10%) (二)建表(二)建表create table Company (company_name varchar(20) primary key,phone varchar(15)

10、 not null)create table Plane (plane_number varchar(10) primary key,plane_type varchar(20) not null,quota_f int not null,quota_s int not null,company_name varchar(20) foreign key references Company(company_name) )create table Line (line_number varchar(10) primary key,airport_s varchar(20) not null,ai

11、rport_e varchar(20) not null,distance int not null,company_name varchar(20) foreign key references Company(company_name) )create table Flight (flight_number varchar(10) primary key,plane_number varchar(10) foreign key references Plane(plane_number) ,line_number varchar(10) foreign key references Lin

12、e(line_number) ,price_f int not null,price_s int not null,flydate varchar(20) not null)create table Passenger (passenger_name varchar(10) primary key,distances int not null,E_mail varchar(20) not null)create table Ticket (ticket_number int identity(1, 1) primary key,flight_number varchar(10) foreign

13、 key references Flight(flight_number),passenger_name varchar(10) foreign key references Passenger(passenger_name),cabin varchar(10) check (cabin = 头等舱 or cabin = 普通舱) not null,pay int check (pay0) not null)create table Wait (passenger_name varchar(10) foreign key references Passenger(passenger_name)

14、 ,12flight_number varchar(10) foreign key references Flight(flight_number) ,cabin_w varchar(10) not null,primary key (passenger_name, flight_number),E_mail varchar(20) not null)(三)视图(三)视图(1)查询头等舱订票量 create view flight_cf (flight_number, count_f)asselect flight_number, count(ticket_number)from Ticket

15、 where cabin = 头等舱 group by flight_number(2)查询普通舱订票量create view flight_cs (flight_number, count_s)asselect flight_number, count(ticket_number)from Ticket where cabin = 普通舱 group by flight_number(3)查询某航班的普通舱和头等舱总量create view flight_q (flight_number, quota_f, quota_s)asselect Flight.flight_number, quota_f, quota_sfrom Flight left join Plane on Flight.plane_number =

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 医学/心理学 > 基础医学

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