版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
数据库课程设计报告摘要国内电影院的售票系统不完善,有很多问题存在,售票效率低下,管理混乱。现今社会是个讲究效率的社会,时间就是金钱。开发简单,便于操作的的软件不仅可以节省时间,还可以节省人力,物理,财力等。建立的影院售票系统,要把影院的售票管理、订票管理,财务管理等日常管理工作实行计算机统一管理,以提高工作效率和管理水平。通过本系统软件,能帮助售票人员利用计算机,快速方便地对影院售票情况,订票情况,剩余座位查询等进行高效的管理。关键字:SQL语句,影院管理系统,数据库设计
目录第一章绪论1.1课题简介1.2设计目的1.3设计内容第二章需求分析2.1需求分析的任务2.2系统目标2.3数据字典与流程图2.4系统框架第三章概念结构设计3.1概念结构设计的方法与步骤3.1.1概念结构设计的方法3.1.3概念结构设计的步骤3.2数据抽象与局部视图设计3.3视图的集成第四章逻辑结构设计4.1E-R图向关系模型的转换4.2数据模型的优化4.3数据库的结构第五章数据库的实现5.1数据库的建立5.3安全性的实现5.4完整性的实现5.5恢复技术的实现第六章运行与结果6.1简单查询和连接查询6.2嵌套查询6.3组合查询和统计查询经理管理影院经理管理影院查询信息电影信息影厅信息经理管理流程图调查用户需求影院职员办公需求功能:可以查到顾客的会员信息,影片、影厅的信息。客购票需求购票办理会员卡经理管理需求查询功能:影片信息影厅信息管理功能④影片信息需求查询功能:导演主演场次上映时间影片格式2.4系统框架在调查完了用户需求之后,就要开始分析用户需求。在此,我们采用自顶向下的结构化分析方法(SA方法)。首先,定义全局概念结构的框架,如图所示。影院管理系统影院管理系统影院职员系统会员系统顾客系统电影票购买系统经理管理系统经理管理系统需要进一步细化。经理管理系统经理管理系统影片信息查询系统影厅信息查询系统将所有子系统全部细化。将所有用户需求分析完毕之后,就要开始构造数据字典了。。数据结构定义如表2.1所示。表2.1数据结构定义数据结构名含义说明组成影院职员定义了影院职员的有关信息职员编号、职员姓名、职员性别、联系电话顾客定义了顾客有关信息顾客编号、姓名、性别影片信息定义了影片的有关信息电影编号、电影名、导演、主演、上映时间、影片格式会员定义了会员相关有关信息会员编号、会员姓名、会员联系电话、会员级别影厅信息定义了影厅有关信息影厅号、座位数、影厅规格影院经理定义了经理有关信息经理编号、经理姓名、经理联系电话、经理性别电影票信息定义了电影票有关信息电影票编号、场次、时间、座位号第三章概念结构设3.1概念结构设计的方法与步骤3.1.1概念结构设计的方法概念设计阶段我采用自底向上的方法,即自顶向下的进行需求分析,然后再自底向上的进行概念结构设计。对已经细化到无法再分的阶段逐步集成在一起,最终合成一个全局概念模式。3.1.3概念结构设计的步骤第一步是进行局部视图的设计:由于高层的数据流图只能反映系统的概貌,而中层流图能较好的反映系统中各局部应用的子系统组成。因此我们先逐一的设计分E-R图。第二步是进行视图的集成:各子系统的E-R图设计好之后,下一步就是要将所有的分E-R图合成一个系统的总E-R图,一般有两个方式,多个分E-R图一次集成,另一种是一次集成两个分E-R图。我想采用一次集成两个分E-R图的方式。3.2数据抽象与局部视图设计职员编号职员编号职员姓名职员性别职员联系电话影院职员电影编号电影编号电影名导演主演上映时间电影规格电影会员姓名会员姓名会员编号会员级别会员联系电话会员经理编号经理编号经理联系电话经理名经理性别影院经理电影票编号电影票编号时间场次电影票座位号影厅号影厅号座位数影厅规格影厅顾客编号姓名性别顾客顾客编号姓名性别顾客3.3视图的集成购买数量购买数量影片影院经理电影票影厅会员卡影院职员顾客办理对应管理服务购买111N1NN1N1M经过逐步细化再进行每两个一集成初步形成一个E-R图,最后得到图3.4总体概念结构E-R图。第四章逻辑结构设计4.1E-R图向关系模型的转换影院职员(职员编号,职员姓名,职员性别,联系电话)顾客(顾客编号,职员编号,姓名,性别)会员卡(会员编号,会员姓名,会员联系电话,会员级别,顾客编号)电影票(顾客编号,影厅号,电影票编号,场次,时间,座位号,购买数量)影院经理(经理编号,经理姓名,经理联系电话,经理性别)管理(影厅号,电影编号,经理编号)影厅(影厅号,座位数,影厅规格)影片信息(电影编号,电影名,导演,主演,上映时间,影片格式)4.2数据模型的优化将转化的关系模式进行优化,最终达到第三范式。1、确定数据依赖影院职员(职员编号,职员姓名,职员性别,联系电话)职员编号→职员姓名,职员编号→职员性别,职员编号→联系电话顾客(顾客编号,职员编号,姓名,性别)(顾客编号,职员编号)→姓名,(顾客编号,职员编号)→性别会员卡(会员编号,会员姓名,会员联系电话,会员级别,顾客编号)会员编号→会员姓名,会员编号→会员联系电话,会员编号→会员级别电影票(顾客编号,影厅号,电影票编号,场次,时间,座位号,购买数量)(顾客编号,影厅号,电影票编号)→场次,(顾客编号,影厅号,电影票编号)→时间,(顾客编号,影厅号,电影票编号)→座位号,(顾客编号,电影票编号)→购买数量影院经理(经理编号,经理姓名,经理联系电话,经理性别)经理编号→经理姓名,经理编号→经理联系电话,经理编号→经理性别影厅(影厅号,座位数,影厅规格)影厅→座位数,影厅→影厅规格影片信息(电影编号,电影名,导演,主演,上映时间,影片格式)电影编号→电影名,电影编号→导演,电影编号→主演,电影编号→上映时间,电影编号→影片格式2、对各关系模式间数据依赖进行极小化处理,消除冗余职员编号→职员姓名,职员编号→职员性别,职员编号→联系电话,(顾客编号,职员编号)→姓名,(顾客编号,职员编号)→性别,会员编号→会员姓名,会员编号→会员联系电话,会员编号→会员级别,顾客编号,影厅号,电影票编号)→场次,(顾客编号,影厅号,电影票编号)→时间,顾客编号,影厅号,电影票编号)→座位号,(顾客编号,电影票编号)→购买数量,经理编号→经理姓名,经理编号→经理联系电话,经理编号→经理性别,影厅→座位数,影厅→影厅规格,电影编号→影片格式,电影编号→电影名,电影编号→导演,电影编号→主演,电影编号→上映时间,3、看这些模式是否符合要求,确定是否要对某些模式进行合并或者分解,最终分解成第三范式:(订单号,电话号,身份证号)(订单号,旅客姓名)(旅客姓名,取票时间,性别,工作单位,机票类型)(旅客姓名,航班号)(旅客姓名,座位号)(航班号,座位号,机票类型)(航班号,起飞地,目的地,起飞时间)4.2基本表结构职员信息表:staff字段名数据类型长度是否为空主/外键描述staffnumberchar10否主键职员编号staffnamevarchar20否职员姓名Staffsexchar2否职员性别Staffphonenumbervarchar20否联系电话顾客信息表:customer字段名数据类型长度是否为空主/外键描述customernumberchar10否主键顾客编号staffnumberchar10否外键职员编号Customernamevarcharr20否姓名Customersexchar2否性别会员卡信息表:member字段名数据类型长度是否为空主/外键描述Membernumberchar10否主键会员编号membernamevarchar20否会员姓名Memberphonenumbervarchar20是会员联系电话memberlevelvarchar10否会员级别customernumberchar10否外键顾客编号电影票信息表:ticket字段名数据类型长度是否为空主/外键描述customernumberchar10否主键外键顾客编号locationschar10否影厅号ticketnumberchar10否电影票编号numbervarchar10否场次timedatetime否时间seatnumbervarchar10否座位号purchasequantityint否购买数量经理信息表:manager字段名数据类型长度是否为空主/外键描述managernumberchar10否主键经理编号manager'snamevarchar10否经理姓名managerphonenumbervarchar20否经理联系电话managersexchar2否经理性别管理表:GL字段名数据类型长度是否为空主/外键描述locationschar10否主键外键影厅号filmnumberchar10否电影编号managernumberchar10否经理编号影厅信息表:screen字段名数据类型长度是否为空主/外键描述locationschar10否主键影厅号SeatingInt否座位数Screensspecificationsvarchar10是影厅规格电影信息表:film字段名数据类型长度是否为空主/外键描述filmnumberchar10否主键电影编号namevarchar10否电影名directorvarchar10是导演starvarchar10是主演Showtimedatetime是上映时间videoformatvarchar10是影片格式
第五章数据库的实现5.1数据库的建立建数据库,SQL语句:CreatedatabaseYYGLONPRIMARY(NAME=YYGL,FILENAME='D:\袁博文\YYGL.mdf',SIZE=4096KB,MAXSIZE=UNLIMITED,FILEGROWTH=1024KB)LOGON(NAME=YYGL_log,FILENAME='D:\袁博文\YYGL_log.ldf',SIZE=1024KB,MAXSIZE=2048GB,FILEGROWTH=10%)5.2数据库基本结构的建立1、基本表的建立(1)职员信息表:STAFFUSEYYGLGOCREATETABLESTAFF(staffnumberchar(10)NOTNULL,staffnamevarchar(20)NOTNULL,staffsexchar(2)NOTNULL,staffphvarchar(20)NOTNULL,PRIMARYKEY(staffnumber))GO(2)顾客信息表:CUSTOMERUSEYYGLGOCREATETABLECUSTOMER(customernumberchar(10)NOTNULL,Customernamevarchar(20)NOTNULL,Customersexchar(2)NOTNULL,Staffnumberchar(10)NOTNULL,PRIMARYKEY(staffnumber,customernumber),FOREIGNKEY(staffnumber)REFERENCESSTAFF(staffnumber))GO(3)会员卡信息表:MEMBERUSEYYGLGOCREATETABLEMEMBER(membernumberchar(10)NOTNULL,membernamevarchar(20)NOTNULL,memberphvarchar(20)NULL,memberlevelvarchar(10)NOTNULL,customernumberchar(10)NOTNULL,staffnumberchar(10)NOTNULL,PRIMARYKEY(membernumber),FOREIGNKEY(staffnumber,customernumber)REFERENCESCUSTOMER(staffnumber,customernumber))GO(4)电影票信息表:TICKETUSEYYGLGOCREATETABLETICKET(staffnumberchar(10)NOTNULL,customernumberchar(10)NOTNULL,locationschar(10)NOTNULL,ticketnumberchar(10)NOTNULL,numbervarchar(10)NOTNULL,timedatetimeNOTnull,seatnumbervarchar(10)NOTNULL,purchasequantityintNOTNULL,PRIMARYKEY(staffnumber,customernumber,locations,ticketnumber),FOREIGNKEY(staffnumber,customernumber)REFERENCESCUSTOMER(staffnumber,customernumber),FOREIGNKEY(locations)REFERENCESSCREEN(locations))GO(5)经理信息表:MANAGERUSEYYGLGOCREATETABLEMANAGER(managernumberchar(10)NOTNULL,managernamevarchar(20)NOTNULL,managersexchar(2)NOTNULL,managerphvarchar(20)NOTNULL,PRIMARYKEY(managernumber))GO(6)管理表:GLUSEYYGLGOCREATETABLEGL(managernumberchar(10)NOTNULL,filmnumberchar(10)NOTNULL,locationschar(10)NOTNULL,PRIMARYKEY(filmnumber,locations),FOREIGNKEY(locations)REFERENCESSCREEN(locations),FOREIGNKEY(managernumber)REFERENCESMANAGER(managernumber),FOREIGNKEY(filmnumber)REFERENCESFILM(filmnumber))GO(7)影厅信息表:SCREENUSEYYGLGOCREATETABLESCREEN(locationschar(10)NOTNULL,seatingintNOTNULL,screensvarchar(10)NULL,PRIMARYKEY(locations))GO(8)电影信息表:FILMUSEYYGLGOCREATETABLEFILM(filmnumberchar(10)NOTNULL,namevarchar(10)NOTNULL,directorvarchar(10)NULL,starvarchar(10)NULL,showtimedatetimeNULL,videoformatvarchar(10)NULL,PRIMARYKEY(filmnumber))GO2、插入数据USEYYGLINSERTINTOSTAFFVALUES('006','于开晨','M',)GOUSEYYGLINSERTINTOCUSTOMERVALUES('0201','赵红','F','001')GOUSEYYGLINSERTINTOFILMVALUES('020','智取威虎山','徐克','张涵予')GOUSEYYGLINSERTINTOMANAGERVALUES('0101','胡星','M',)GOUSEYYGLINSERTINTOMEMBERVALUES('1001','赵红',,'1','0201','001')GOUSEYYGLINSERTINTOSCREENVALUES('1','200','2')GO3、视图建立建立管理人员为男性的视图A:4、建立索引为会员卡信息表的memberlevel列创建名为A的索引useYYGLGOcreateindexAonMEMBER(memberlevel)GO5、创建游标声明一个名为A的游标,用于读取由001号雇员服务的顾客USEYYGLGODECLAREAAcursorFORSELECT*FROMCUSTOMERwherestaffnumber='001'openAAfetchfromAAGO6、存储过程的创建USEYYGLGOcreateprocedure[dbo].[MEMBER](@membernamevarchar(20))ASinsertintoMEMBER(membername)values(@membername)GO7、触发器建立创建一个触发器B,使在对会员卡信息表进行修改插入时都会自动提示:
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 许昌学院《社会学概论》2023-2024学年第一学期期末试卷
- 许昌学院《模拟电子技术》2022-2023学年第一学期期末试卷
- 许昌学院《教育统计与测量》2022-2023学年第一学期期末试卷
- 许昌学院《护理伦理与卫生法规》2022-2023学年第一学期期末试卷
- 北京市居住小区其他垃圾收集运输服务合同
- 安徽省电商平台服务合同
- 2024年患者十大安全目标理论考核试题
- 外研版九年级上册语文古诗翻译
- 探索电话机的奇妙之旅
- 清淤工程合同范本样本范例格式
- 2024版房屋市政工程生产安全重大事故隐患判定标准内容解读
- 2024-2025学年高三上学期期中家长会 课件
- 《念奴娇·赤壁怀古》教学设计
- 水手工艺技能题
- 10kV及以下配网及客户配电工程验收管理实施办法
- 老年人与糖尿病
- 光接口传输距离计算方法(共6页)
- 顶管施工监测
- 《糖尿病的治疗》PPT课件.ppt
- 铁路工务线路工作业指导
- 小学美术《14虾和蟹(二)》PPT课件
评论
0/150
提交评论