数据库系统分析与设计课程设计报告(共33页).doc

上传人:飞****2 文档编号:14253131 上传时间:2022-05-03 格式:DOC 页数:33 大小:1,008KB
返回 下载 相关 举报
数据库系统分析与设计课程设计报告(共33页).doc_第1页
第1页 / 共33页
数据库系统分析与设计课程设计报告(共33页).doc_第2页
第2页 / 共33页
点击查看更多>>
资源描述

《数据库系统分析与设计课程设计报告(共33页).doc》由会员分享,可在线阅读,更多相关《数据库系统分析与设计课程设计报告(共33页).doc(33页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、精选优质文档-倾情为你奉上课程设计(论文)课程名称: 数据库系统分析与设计 题 目: 城南客运站汽车管理系统 数据库设计与实现 院 (系): 管理学院 专业班级: 信息管理与信息系统 姓 名: 学 号: 指导教师: 张新生 2012年 12 月 4 日西安建筑科技大学课程设计(论文)任务书专业班级: 信管1001 学生姓名: 指导教师(签名): 一、课程设计(论文)题目 城南客运站汽车信息管理系统数据库设计与实现二、本次课程设计(论文)应达到的目的 数据库系统分析与设计课程设计是信息管理与信息系统专业集中实践性环节之一,是学习完数据库数据库系统原理及技术及数据库系统分析与设计课程后进行的一次全

2、面的综合练习。其目的在与加深对数据库基础理论和基本知识的理解,掌握借助PowerDesigner开发和设计一个小型数据库系统时设计数据库系统模型的基本方法,提高运用数据库解决实际问题的能力。 三、本次课程设计(论文)任务的主要内容和要求(包括原始数据、技术参数、设计要求等) 要求学生能独立完成一个数据库模型的设计与实现,包括:1) 数据库系统需求分析;2) 数据库概念模型设计;3) 数据库逻辑模型设计;4) 数据库物理模型的实现;5) 完成不少于6000字的课程设计报告撰写。四、应收集的资料及主要参考文献: 1 王珊, 萨师煊. 数据库系统概论(第4版). 北京:高教出版社,2006年5月.2

3、 赵韶平等.PowerDesigner系统分析与建模(第2版). 北京:清华大学出版社,2010.3 Data Modeling and Relational Database Design. Oracle Inc. 2001.五、审核批准意见教研室主任(签字) 专心-专注-专业设计总说明随着时代的进步、社会的发展、人们的生活形式与习惯也越来越多样化,出行成为了人们生活中的一个重要组成部分,而汽车成为许多人出行选择的交通工具。面对巨大数量的乘客的购票乘车需要,汽车站就要选择使用先进的管理方法来实现方便、快捷的售票、准确的查询、有效的汽车管理。城南客运站汽车信息管理系统是模拟西安城南客运站票务系

4、统的一部分。城南客运站汽车信息管理系统数据库设计与实现,首先对客运站的业务进行需求调查和分析,并根据调查和分析结果画出城南客运站汽车管理信息系统的业务流程图和数据流程图,在业务流程图的基础之上利用PowerDesigner创建该业务的数据库概念模型(CDM模型),然后检查CDM的正确性,在CDM模型正确后将CDM模型转换为数据库逻辑模型(LDM模型),然后生成数据库物理模型(PDM模型),然后将PDM模型生成所需的数据库。关键字:PowerDesigner,城南客运站汽车信息管理系统,概念数据模型,逻辑数据模型,物理数据模型目 录1 绪论1.1系统简介随着计算机的普及,信息处理量的逐渐扩大,手

5、工处理方式远远不能满足人们管理活动的需要,各种工作都逐渐由手工转为自动化,使许多复杂、繁琐、且需要很多人力的工作变得简单。汽车站每天产生售票、乘客查询、汽车管理等行为,数量多使得汽车站汽车管理的数据量大,而且速度要求要快,传统的人力行为适应计算机应用软件的使用则能很好地满足汽车站的这一需要,提高汽车管理人员和调度人员的工作效率,节约相关管理成本。数据库能保证数据的正确性、安全性、完整性,所以各种软件离不开数据库,数据库在计算机领域中占有很大的地位,正因为数据库如此重要,所以对设计数据库时要正确、效率高。城南客运站汽车信息管理系统的数据库主要实现了乘客对汽车票信息的查询,售票员对车票的打印,以及

6、对汽车班次的管理和对所有汽车的调度,从而为客运站的整个票务系统服务。1.2设计目的本系统的任务目标是,实现方便、快速售票,有效的汽车管理和调度,使用户准确了解车票的票价、余票、发车时间、班次等车票信息,实现系统的数据库,并对该数据库进行一定的维护功能。1.3设计内容1) 对城南客运站汽车管理进行需求分析,包括数据分析、功能分析。首先对乘客、汽车、售票员、车票、路线进行数据分析;然后对乘客、售票员进行功能分析。2) 依据数据分析结果绘制系统的业务流程图和数据流程图。3) 使用PowerDesigner对汽车管理系统建立数据库概念数据模型(CDM模型),主要任务是建立实体、联系、定义域、业务规则以

7、及检查CDM模型的正确性。4) 由系统的概念模型转换生成逻辑数据模型(LDM模型)。5) 有CDM模型生成物理数据模型(PDM模型)。6) 连接数据库,由PDM模型生成物理数据库,实现汽车管理系统的数据库。2 需求分析2.1 .需求分析的任务本系统是城南客运站汽车管理系统,此系统主要分为乘客、运输公司和售票员三方的服务。运输公司提供路线和汽车的资料,客运站则对在本站收发的班次和车票进行管理,而乘客能得到的服务应该有班次路线和剩余票数的查询。通过调查、收集和分析,获得用户对城南客运站汽车管理系统数据库的如下需求:1)信息需求。 路线:出发地,目的地,出发时间。 乘客:乘客姓名,乘客身份证号,乘客

8、ID。 汽车:汽车ID,班次,车型,座位容量。 车票:票价,燃油费,站务费,总计,余票量,班次,目的地。 售票员:工号,姓名,窗口号。2)处理要求。 乘客:可以购票,查询余票信息,查询所的乘汽车信息。 售票员:可以查询车票信息,打印车票。 汽车(司机):查询班次,查询路线。2.2 系统数据流程分析1)基本业务调查此次设计通过网络检索的方法,对所设计系统的业务进行调查,明确其业务流程图,如图2-1。图2-1 汽车管理系统业务流程图2)数据流程图根据调查结果和业务流程图,给出系统业务数据流程图,如下图。顶层数据流程图:图2-2 顶层数据流程图第一层数据流程图:图2-3 第一层数据流程图2.3 数据

9、字典在数据流程图中,数据信息和处理过程如下所示:1)数据流定义可以通过表格的形式给出数据流程图的主要数据流,如表2.1所示。表2.1 汽车管理系统主要数据流定义序号名称结构定义最大数据流量1乘客乘客ID+姓名+身份证号5000次/天2汽车汽车ID+车型+座位容量500次/天3路线目的地+出发地+出发时间1000次/天4车票车票ID+票价+燃油费+站务费+班次5000次/天5售票员售票员ID+窗口号+姓名1000次/天2)数据存储定义可以采用如下表格的形式给出系统的主要数据定义,如表2.2所示。表2.2 汽车管理系统主要数据存储定义编号名称输入输出数据量存取频度存取方式说明D1购票信息乘客信息查

10、看票价,余票量,25000条1000次/天联机处理;检索和更新;随即检索车票ID唯一且不为空D2班次信息路线信息班次,出发时间,目的地,5000条1000次/天联机处理;检索和更新;随即检索班次唯一不为空3)处理过程可以采用如下表格的形式给出系统的主要处理过程定义,如表2.3所示。表2.3 汽车管理系统主要处理过程定义序号处理过程名称输入输出处理说明P0汽车管理班次信息,车票信息汽车信息对汽车按类编号,将汽车编号信息化管理,统一调度P0.1购票乘客信息,路线信息车票信息对车票分类编号,索引P1.2汽车管理车票信息,班次信息汽车信息对汽车分类编号,索引3 概念模型设计3.1 概念模型设计的方法和

11、步骤3.1.1 建立实体1)打开PowerDesigner开发环境选择FileNew项在打开窗口中选择Conceptual Data Model项如图3-1所示。 图3-1 创建Conceptual Data Model2)在Palette工具栏中,选择Entity实体图标,在屏幕任意位置单击左键,则一个实体放置在模型窗口上。然后在窗口空白处单击右键,鼠标恢复箭头形状。3)双击实体图形符号打开Entity Properties(实体属性)窗口,定义实体的属性,如图3-2所示。图3-2 实体属性窗口4)实体属性定义完毕后单击“确定”按钮,返回CDM主窗口。实体的图形如图3-3所示。图3-3 车票

12、实体的图形符号5)重复上述(2)(4)的步骤,依次创建其他各实体。所有实体创建完毕以后,结果如图3-4所示。图3-4 所有实体符号图3.1.2建立联系实体创建完毕以后,就可以在实体之间建立联系。建立联系的过程如下:1)在Palette工具栏中选择Relationship图标,在有联系的两个实体中的一个实体图形符号上单击左键,拖动鼠标至另外一个实体,释放鼠标就可在两个实体之间建立联系。2)选中联系的图形符号双击打开联系属性定义窗口其中General页的内容如图3-5所示。3)在Cardinalities页中填写联系的细节信息,如图3-6所示。4)定义完毕后单击“确定”返回CDM主窗口。5)重复上

13、述(2)(4)步骤,建立其他所有实体之间的联系。 图3-5 General选项卡 图3-6 Cardinalities选项卡6)所有实体联系创建完毕以后,即生成了汽车管理系统的CDM模型,如图3-7所示。图3-7 城南客运站汽车管理系统CDM模型3.1.3 定义域在城南客运站汽车信息管理系统中,实体车票中的“票价”,“燃油费”,“站务费”,“合计”等属性都是数值型数据,数据类型和宽度都相同,所以可以先在模型定义一个公用的域,然后将域连接到各个属性。1)选择ModelDomains菜单项,打开List of Domains,在其中新增一个域,如图3-8所示。图3-8 域列表窗口2) 定义完毕以后

14、,单击“确定”按钮,返回CDM模型。3) 双击要引用的域的实体图形符号,打开实体定义窗口,选择Attributes页,增加一个属性,但不要定义数据类型,只需在Domain栏中单击,则显示所有预先定义好的域名,选择合适的域,然后单击“Apply”按钮,就可以看到属性的数据类型变为域的数据类型。3.1.4 定义业务规则业务规则是信息系统所描述对象特定的数据完整性,在城南客运站汽车信息管理系统中,需要定义以下几种业务规则。 校验型:描述信息系统的数据约束。在城南客运站汽车信息管 理系统中,发车时间必须先于到达时间,座位号必须小于座位容量。 公式型:描述信息系统的计算。在城南客运站汽车管理信息系统中,

15、合计等于票价、燃油费、站务费之和;余票等于座位容量减去座位号。定义业务规则的具体过程如下:1)在CDM模型中选择ModelBusinessRules命令,打开List of Business Bules(业务规则定义)窗口,如图3-9所示。图3-9 List of Business Bules 窗口2) 单击Add a Row 图标,在Name 栏中输入名称“总计”,在Code栏中输入Total_Sum,在Rule Type栏中选择业务规则的类型为Formula。按照同样的方法添加“余票量”业务规则。3) 定义完毕以后单击Apply按钮,选中刚才定义的业务规则,单击Properties图标,打

16、开Business Rules Properties窗口,选择Expression选项卡,在选择Client选项卡,表示在客户端是想的业务规则。在其中输入计算方法。“总计=票价+燃油费+站务费”,如图3-10所示。图3-10 合计的业务规则4)按照同样的方法定义“余票量”的业务规则,“余票量=座位容量-座位号”如图3-11所示图3-11 余票量的业务规则5) 定义完毕后单击“确定”按钮返回。6) 单击“业务规则定义”窗口的OK按钮,返回CDM模型主窗口。7) 双击“车票”实体,在Attributes选项卡中选择“总计”并查看属性,在Rules选项卡,单击AddObjects图标,在Select

17、ion窗口中选择新增的业务规则“总计”,将新增的业务规则添加到“车票”实体中。按同样方法,将“余票量”业务规则添加到“余票”属性中。3.1.5检查CDM的正确性 定义好CDM模型以后,利用系统自带的检查功能检查模型的错误,为下一步的工作打下良好的基础。具体步骤如下:1) 选择ToolsCheck Model命令,打开Check Model Parameters窗口,如图3-12所示。图3-12 Check Model Parameters 窗口2)设置检查选项后,单击“确定”按钮,开始执行检查。完毕后弹出Result List窗口,如图3-13所示。图3-13 Result List 窗口3)

18、 查看结果并根据提示进行修改,直到没有错误和警告为止。3.1.6 生成CDM模型文档城南客运站系统模型文档生成的具体步骤如下:1)选择FileNew菜单项,在打开的窗口选择Multi-Model Report选项单击“OK”按钮打开生成模型文档设置窗口。1) 单击“确定”按钮,进入模型文档设计窗口。2) 在模型设计窗口可以修改报告的内容,以满足实际要求。3) 修改完毕后,单击“OK”按钮返回到模型文档设计窗口,选择窗口中的RTF图标,在弹出窗口中输入模型文档的文件名,单击“OK”按钮开始生成文档。然后可以利用Word打开文档。3.2 系统概念模型根据系统的需求分析,得出城南客运站汽车信息管理系

19、统数据库的概念模型,如图3-14所示。图3-14 城南客运站汽车信息管理系统CDM模型4 逻辑模型设计4.1 逻辑模型设计的方法CDM生成LDM的具体方法如下:1)打开CDM模型,选择ToolsGenerate Logical Data Model命令,打开LDM Generation Options窗口。2)选择Detail选项卡,进行其他选项的设置。3)选择Selection选项卡,可以选择CDM、实体。 4)单击按钮“确定”按钮,开始生成LDM。 4.2 逻辑模型实现城南客运站汽车信息管理系统数据库逻辑数据模型(LDM模型)如图4-1所示。 图4-1 城南客运站汽车信息管理系统数据库的L

20、DM模型 4.3 数据完整性约束定义根据上面的关系模式,数据库的完整性约束如下所示:1)实体完整性约束城南客运站汽车信息管理系统数据库的每一个关系模式中的主码如表4.1所示。表4.1 各关系模式中的主码实体主键路线目的地汽车汽车ID乘客乘客ID售票员工号车票车票ID2)参照完整性约束关系模式的参照完整性如表4.2所示:表4.2 关系模式的参照完整性实体参照实体主键外键路线汽车目的地汽车ID汽车车票汽车ID目的地车票汽车车票ID汽车ID乘客车票乘客ID车票ID售票员工号5 物理数据库模型设计与实现5.1 物理数据库模型的图示1)打开CDM模型,选择ToolsGenerate Physical D

21、ata Model命令,在PDM Generate Options窗口,在General选项卡中选择生成PDM的方式及参数。 2)选择Detail选项卡,进行细节选项设置。3)选择Selection选项卡,选择要转换为PDM表的实体。4)单击“确定” 按钮生成PDM模型,如图5-1所示。图5-1城南客运站汽车信息管理系统数据库物理数据模型5.2 物理数据库模型的详细表示 数据项清单,如表5.1所示。表5.1 数据项清单名称代码域数据类型长度乘客IDpassenger IDCharacters (20)20乘客姓名passenger nameCharacters (20)20余票RemainTi

22、cketInteger出发地start placeVariable characters (200)200发车时间start timeDate & Time合计TotalMoney姓名WorkerNameCharacters (20)20工号WorkerIDCharacters (20)20座位号SeatNamberInteger座位号SeatNamberInteger座位容量seat volumeInteger所需时间time needFloat检票口CheckWindowInteger检票口CheckWindowInteger汽车IDbus IDCharacters (20)20燃油费Fu

23、elFeeMoney班次BusOrderCharacters (10)10目的地destinationVariable characters (200)200票价TicketPriceMoney窗口号WindowIDInteger站务费OfficeFeeMoney身份证号crad IDCharacters (18)18车型bus typeCharacters (50)50车票IDTicketIDCharacters (50)50表的清单,如图5.2所示。表5.2 表的清单名称代码乘客乘客售票员售票员售票员乘客售票员乘客售票员车票售票员车票汽车汽车路线路线车票车票 引用的清单表5.3 引用的清单

24、名称代码父表格子表格外键列乘客汽车乘客汽车汽车乘客汽车ID售票员乘客售票员乘客2乘客售票员乘客乘客ID售票员乘客售票员乘客售票员售票员乘客工号售票员车票售票员车票售票员售票员车票工号售票员车票售票员车票2车票售票员车票车票ID汽车路线汽车路线路线汽车目的地车票乘客车票乘客2乘客车票乘客ID车票乘客车票乘客车票乘客车票ID车票路线车票路线路线车票目的地5.3 物理数据库模型的实现5.3.1连接数据库只有在与用户数据库正确连接以后,才能把设计的PDM生成到数据库中。 数据结构生成到用户数据库中,用户才能在这些结构中保存信息与索引信息。PDM与用户数据连接的步骤如下:1)在PDM窗口中选择Datab

25、aseConnect命令,打开Connect to a Data Source窗口,如图5-1所示。图5-1 Connect to a Data Source窗口2)在ODBC machine data source下拉列表框中选择建立一个数据源,单击Connect按钮。5.3.2 访问数据库1)选择DatabaseChange Current DBMS命令,选择用户的DBMS。2)改变当前PDM的目标DBMS时,需要考虑应该保护的原DBMS对象。5.3.3 生成数据库PowerDesigner设计的PDM模型可以直接生成到数据库中,生成数据库的过程如下:1) 选择DatabaseGenera

26、te Database命令,打开Database Generation窗口,连接上以后查看Database 信息,如图5-2所示。图5-2 Database Information2) 选择Option选项卡,在选项卡中可以对各类PDM对象设置参数。3) 选择Format选项卡,在选项卡中设置生成格式信息。4) 选择Selection选项,在选项卡中选择需要生成数据库的对象。5) 选择Preview选项卡进行预览或单击“确定”按钮生成数据库,如图5-2所示。图5-2 生成数据库窗口5.3.4 物理数据库的实现以下是有PDM生成物理数据库的部分SQL语句:/*=*/* Table: 乘客 */*

27、=*create table 乘客 ( 乘客ID char(20) not null, 汽车ID char(20) not null, 车票ID char(50) null, 乘客姓名 char(20) null, 身份证号 char(18) null, constraint PK_乘客 primary key nonclustered (乘客ID)go/*=*/* Table: 路线 */*=*create table 路线 ( 目的地 varchar(200) not null, 出发地 varchar(200) null, 发车时间 datetime null, 所需时间 float n

28、ull, constraint PK_路线 primary key nonclustered (目的地)go/*=*/* Table: 车票 */*=*create table 车票 ( 车票ID char(50) not null, 目的地 varchar(200) null, 乘客ID char(20) not null, 票价 金额 null, 燃油费 金额 null, 站务费 金额 null, 余票 int null, 班次 char(10) null, 座位号 int null, 检票口 int null, 合计 金额 null, constraint PK_车票 primary k

29、ey nonclustered (车票ID)go/*=*/* Table: 售票员 */*=*create table 售票员 ( 工号 char(20) not null, 窗口号 int null, 姓名 char(20) null, constraint PK_售票员 primary key nonclustered (工号)go/*=*/* Table: 汽车 */*=*create table 汽车 ( 汽车ID char(20) not null, 目的地 varchar(200) not null, 车型 char(50) null, 座位容量 int null, constra

30、int PK_汽车 primary key nonclustered (汽车ID)go/*=*/* Table: 售票员 */*=*create table 售票员 ( 工号 char(20) not null, 窗口号 int null, 姓名 char(20) null, constraint PK_售票员 primary key nonclustered (工号)go/*=*/* Domain: 金额 */*=*/create type 金额 from numeric(8,2)Go/*=*/* Index: 乘客汽车_FK */*=*/create index 乘客汽车_FK on 乘客

31、 (汽车ID ASC)go/*=*/* Index: 车票乘客_FK */*=*/create index 车票乘客_FK on 乘客 (车票ID ASC)go在SQL server中生成的表如图5-3所示:图5-3 SQL server中生成的表总结通过这次数据库实验,我学到了很多东西。我完全按照数据库的设计流程一步一步的来做,从该概念数据库模型到逻辑数据库设计再到物理数据库设计。并且我在做逻辑数据库的设计的时候,积累了大量的文档资料,真正达到了用文档来驱动数据库开发的目的通过按照数据库的步骤一步步来,遇到不懂的概念,术语就往前翻书查询相应的章节,就这样一步一步的把整本书有复习了一遍。其次,

32、掌握了使用各种计算机资料和有关参考资料,培养了检索资料和参考相关文献的能力;锻炼了绘制图标和使用图表的基本技能;提高了使用word文档和排版的水平。最后,本次课程设计的任务已经基本完成,当然还可以在此基础上进一步改进。此次课设让我学习了许多知识,为以后的工作奠定了扎实的基础。参考文献1 赵韶平等.PowerDesigner系统分析与建模(第2版). 北京:清华大学出版社,2010.2 慕静.管理信息系统开发方法、工具与应用(第1版).北京:清华大学出版社,2010.3 萨师煊,王珊.数据库系统概论(第1版).北京:高等工业出版社,2000.4 孟宪虎.大型数据库管理系统技术、应用与实例分析(第2版).北京:电子工业出版社,2011.5 姚朗思.民航飞机信息管理系统数据库设计学士毕业论文.西安:西北工业大学,2009.6 网站.城南客运站,2008.

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

当前位置:首页 > 教育专区 > 教案示例

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁