您好,欢迎访问三七文档
当前位置:首页 > 行业资料 > 酒店餐饮 > 数据库课程设计--机票预订系统.
目录1前言.......................................................12需求分析...................................................12.1课程设计目的..........................................12.2课程设计任务..........................................12.3设计环境..............................................22.4开发语言..............................................23分析和设计.................................................23.1系统E-R模型..........................................23.2表空间及表的设计......................................33.3视图设计..............................................83.4存储过程、函数、包的设计.............................123.5触发器设计...........................................173.6角色、用户、权限设计.................................183.7备份方案设计.........................................194课程设计总结..............................................20参考文献....................................................21致谢......................................................2111前言航空客运业务诞生已有近一个世纪了,作为现有交通工具中最方便快捷的一种,它确确实实地给民众的生活、出行带来了极大的方便。随着社会的进步,人们的生活水平得到很大的提高,民航的发展也很迅速,乘坐飞机的旅客也大大增多。假如现在没有售票系统,民航将也不会存在,人们的出行极大不便。换句话说,一个功能完善的机票预定信息管理系统对人们的日常生活已经显得尤其重要。现设计一个机票预定信息管理系统的数据库。首先根据问题需求设计E-R模型,包括几个主要的实体,如航空公司、飞机、乘客、航班、机票、业务员等以及相关的联系。然后再转根据E-R模型设计出相应的关系模型,对于关系模型的每一个关系,可以设计出相应的表,接着分配表空间、创建视图、设计存储过程、函数和触发器以及设计安全与备份策略。2需求分析2.1课程设计目的通过专业课程设计Ⅱ,即大型数据库系统课程设计,有助于培养学生综合运用数据库相关知识解决实际问题的能力。本设计要求对实际问题进行需求分析,提炼实际问题中的数据,建立关系模型,并在大型数据库中得以实现。同时要求对数据库的运营、管理及使用上进行必要的规划和实现。2.2课程设计任务系统需要管理以下主要信息:(1)航班基本信息,包括航班的编号、飞机名称、机舱等级等。(2)机票信息,包括票价、折扣、当前预售状态及经手业务员等。(3)客户基本信息,包括姓名、联系方式、证件及号码、付款情况等。基本要求:(1)根据需求,补充必要的数据库实体,建立ER模型,通过ER图表示。(2)在Oracle中创建该系统的数据库,并在数据库中实现各表,写入一定的数据。(3)从实际查询应用出发,为一些主要的应用模块设计至少3个参数化视图。2(4)从数据检验的角度出发,为相关的表建立至少1个触发器。(5)从数据更新或修改的角度出发,设计至少1个存储过程。(6)从安全的角度出发,规划系统的角色、用户、权限,并通过相关的SQL实现。(7)预计每个表的大致容量和增长速度,指定备份的方案,写出相关的备份命令。2.3设计环境(1)WINDOWS2000/2003/XP系统(2)Oracle数据库管理系统2.4开发语言PL/SQL语言3分析和设计3.1系统E-R模型经过分析可以知道,机票预定信息管理系统一共有航空公司、飞行、航班、机舱、机票、乘客和业务员这几个实体,航空公司有公司编号、公司名、公司电话和公司地址这几个属性;飞机有飞机编号、飞机名称两个属性;航班有航班号、出发地、目的地、起飞时刻和飞行时间这几个属性;机舱有机舱等级、座位数、定价和折扣这几个属性;机票有机票编号、登机日期、预定状态、座位号这几个属性;乘客有身份证号、姓名、联系电话、住址这几个属性;业务员有业务员编号、业务员姓名、业务员身份证号、联系电话和住址这几个属性。一个航空公司有多架飞机和多名业务员,一架飞机可有多个航班,一个航班有多种机舱等级,一个机舱可有多张机票;乘客、业务员和机票之间有售票联系,售票联系有售票日期这一属性。根据以上分析可以画出系统E-R图,系统E-R图如图3.1所示:3乘客姓名身份证号联系电话住址业务员姓名业务员编号身份证号住址联系电话航空公司公司名公司编号公司电话公司地址飞机飞机编号飞机名称售票属于机票座位号折扣n属于n1属于n航班航班号出发地目的地起飞时刻飞行时间11属于n1机票编号n销售日期1定价属于n1登机日期购票n1机舱机舱等级座位数属于n1航班号销售日期图3.1系统E-R图3.2表空间及表的设计(1)表空间的设计。经过分析可知,乘客表、机票信息表和机票销售表数据量比较大,可单独分配表空间,其他的表数据量较少,可一起使用一个表空间。创建表分配表空间和添加数据文件,SQL语句如下:CREATESMALLFILETABLESPACEPASSENGERDATAFILE'F:\APP\ORACLE\ORADATA\ORCL\TICKETSALE\passenger.dbf'SIZE100MAUTOEXTENDONNEXT5MMAXSIZEUNLIMITEDLOGGINGEXTENTMANAGEMENTLOCALSEGMENTSPACEMANAGEMENTAUTO;CREATESMALLFILETABLESPACETICKETDATAFILE'F:\APP\ORACLE\ORADATA\ORCL\TICKETSALE\ticket.dbf'SIZE100MAUTOEXTENDONNEXT5MMAXSIZEUNLIMITEDLOGGINGEXTENTMANAGEMENTLOCALSEGMENTSPACEMANAGEMENTAUTO;CREATESMALLFILETABLESPACETICKETSALEDATAFILE'F:\APP\ORACLE\ORADATA\ORCL\TICKETSALE\ticketsale.dbf'SIZE100MAUTOEXTENDONNEXT5MMAXSIZEUNLIMITEDLOGGINGEXTENTMANAGEMENTLOCALSEGMENTSPACEMANAGEMENTAUTO;CREATESMALLFILETABLESPACEOTHERSDATAFILE'F:\APP\ORACLE\ORADATA\ORCL\TICKETSALE\others.dbf'SIZE100MAUTOEXTENDONNEXT5MMAXSIZEUNLIMITEDLOGGINGEXTENTMANAGEMENTLOCALSEGMENTSPACEMANAGEMENTAUTO;4表空间结构如图3.2所示:图3.2表空间结构图(2)关系模型的设计。根据E-R模型,可以得出相应的关系模型,关系模型如下:company(cno,cname,ctel,caddress)passenger(pID,pname,ptel,paddress)salesman(sno,sID,sname,stel,saddress,cno)airplane(ano,aname,cno)flight(fno,departure,arrival,time,flytime,ano)cabin(fno,cblevel,seats,price)ticket(tno,fno,cblevel,flydate,status,seat,discount)ticketsale(tno,pID,sno,saledate)(3)表的创建。对于关系模型的每一个关系,可以得出相应的一张表,创建表的SQL语句如下:CREATETABLESYSTEM.COMPANY(CNOVARCHAR2(10)NOTNULL,CNAMEVARCHAR2(20)NOTNULL,CTELVARCHAR2(20),CADDRESSVARCHAR2(50),PRIMARYKEY(CNO)VALIDATE)TABLESPACEOTHERS;CREATETABLESYSTEM.PASSENGER(PIDVARCHAR2(20)NOTNULL,PNAMEVARCHAR2(20)NOTNULL,PTELVARCHAR2(20),5PADDRESSVARCHAR2(50),PRIMARYKEY(PID)VALIDATE)TABLESPACEPASSENGER;CREATETABLESYSTEM.SALESMAN(SNOVARCHAR2(10)NOTNULL,SIDVARCHAR2(20)NOTNULL,SNAMEVARCHAR2(20)NOTNULL,STELVARCHAR2(20),SADDRESSVARCHAR2(50),CNOVARCHAR2(10)NOTNULL,PRIMARYKEY(SNO)VALIDATE,FOREIGNKEY(CNO)REFERENCESSYSTEM.COMPANY(CNO)VALIDATE)TABLESPACEOTHERS;CREATETABLESYSTEM.AIRPLANE(ANOVARCHAR2(10)NOTNULL,ANAMEVARCHAR2(20)NOTNULL,CNOVARCHAR2(10)NOTNULL,PRIMARYKEY(ANO)VALIDATE,FOREIGNKEY(CNO)REFERENCESSYSTEM.COMPANY(CNO)VALIDATE)TABLESPACEOTHERS;CREATETABLESYSTEM.FLIGHT(FNOVARCHAR2(10)NOTNULL,DEPARTUREVARCHAR2(20)NOTNULL,ARRIVALVARCHAR2(20)NOTNULL,TIMEDATENOTNULL,FLYTIMEINTERVALDAYTOSECONDNOTNULL,ANOVARCHAR2(10)NOTNULL,PRIMARYKEY(FNO)VALIDATE,FOREIGNKEY(ANO)REFERENCESSYSTEM.AIRPLANE(ANO)VALIDATE)TABLESPACEOTHERS;CREATETABLESYSTEM.CABIN(FNOVARCHAR2(10)NOTNULL,CBLEVELNUMBER(1)NOTNULL,SEATSNUMBER(3)NOTNULL,PRICENUMBER(5)NOTNULL,PRIMARYKEY(FNO,CBLEVEL)VALIDATE,FOREIGNKEY(FNO)REFERENCESSYSTEM.FLIGHT(FNO)VALIDATE)TABLESPACEOTHERS;CREATETABLESYSTEM.TICKET(6TNONUMBER(10)NOTNULL,FNOVARCHAR2(10)NOTNULL,CBLEVELNUMBER(1)NOTNULL,FLYDATEDATENOTNULL,STATUSNUMBER(1)DEFAULT1NOTNULL,SEATNUMBE
本文标题:数据库课程设计--机票预订系统.
链接地址:https://www.777doc.com/doc-4108782 .html