




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
数据库系统概论AnIntroductiontoDatabaseSystem第七章数据库设计AnIntroductiontoDatabaseSystem第七章数据库设计7.1数据库设计概述7.2需求分析7.3概念结构设计7.4逻辑结构设计7.5数据库的物理设计7.6数据库实施和维护7.7小结AnIntroductiontoDatabaseSystem数据库设计概述数据库设计数据库设计是指对于一个给定的应用环境,构造(设计)优化的数据库逻辑模式和物理结构,并据此建立数据库及其应用系统,使之能够有效地存储和管理数据,满足各种用户的应用需求,包括信息管理要求和数据操作要求。目标:为用户和各种应用系统提供一个信息基础设施和高效率的运行环境。AnIntroductiontoDatabaseSystem7.1数据库设计概述7.1.1数据库设计的特点7.1.2
数据库设计方法7.1.3数据库设计的基本步骤7.1.4数据库设计过程中的各级模式AnIntroductiontoDatabaseSystem7.1.1数据库设计的特点数据库建设的基本规律三分技术,七分管理,十二分基础数据管理:数据库建设项目管理、企业(即应用部门)的业务管理基础数据收集、入库更新新的数据数据库结构设计应该与应用系统的行为设计相结合结构(数据)设计:设计数据库框架或数据库结构行为(处理)设计:设计应用程序、事务处理等AnIntroductiontoDatabaseSystem数据库设计的特点(续)现实世界概念模型设计子模式设计物理数据库设计逻辑数据库设计建立数据库数据分析功能分析功能模型功能说明事务设计程序说明应用程序设计程序编码调试结构和行为分离的设计
AnIntroductiontoDatabaseSystem7.1数据库设计概述7.1.1数据库设计的特点7.1.2数据库设计方法7.1.3数据库设计的基本步骤7.1.4数据库设计过程中的各级模式AnIntroductiontoDatabaseSystem7.1.2数据库设计方法手工与经验相结合方法(手工试凑法)设计质量与设计人员的经验和水平有直接关系数据库运行一段时间后常常不同程度地发现各种问题,增加了维护代价规范设计法新奥尔良(NewOrleans)方法:将数据库设计分为若干阶段和步骤基于E-R模型的数据库设计方法:概念设计阶段广泛采用3NF(第三范式)的设计方法:逻辑阶段可采用的有效方法ODL(ObjectDefinitionLanguage)方法:面向对象的数据库设计方法注:规范设计法本质上说仍是手工设计方法,其基本思想是过程迭代和逐步求精AnIntroductiontoDatabaseSystem数据库设计方法(续)计算机辅助设计法在数据库设计的某些过程中模拟某一规范化设计的方法,并以人的知识或经验为主导,通过人机交互方式实现设计中的某些部分。这些工具统称CASE(计算机辅助软件工程ComputerAidedSoftwareEngineering),如:SYSBASE公司的PowerDesignerOracle公司的Design2000CA公司的ERWinRational公司的RationalRoseMicrosoft公司的Vision。自动化设计法完全由计算机完成数据库设计AnIntroductiontoDatabaseSystem7.1数据库设计概述7.1.1数据库设计的特点7.1.2数据库设计方法7.1.3数据库设计的基本步骤7.1.4数据库设计过程中的各级模式AnIntroductiontoDatabaseSystem7.1.3数据库设计的基本步骤数据库设计分6个阶段需求分析概念结构设计逻辑结构设计物理结构设计数据库实施数据库运行和维护
需求分析和概念设计独立于任何数据库管理系统逻辑设计和物理设计与选用的DBMS密切相关AnIntroductiontoDatabaseSystem数据库设计的基本步骤(续)一、数据库设计的准备工作:选定参加设计的人1.系统分析人员、数据库设计人员
自始至终参与数据库设计2.用户和数据库管理员主要参加需求分析和数据库的运行维护3.应用开发人员(程序员和操作员)在系统实施阶段参与进来,负责编制程序和准备软硬件环境
AnIntroductiontoDatabaseSystem数据库设计的基本步骤(续)二、数据库设计的过程(六个阶段)
⒈需求分析阶段准确了解与分析用户需求(包括数据与处理)最困难、最耗费时间的一步
AnIntroductiontoDatabaseSystem数据库设计的基本步骤(续)
⒉概念结构设计阶段整个数据库设计的关键通过对用户需求进行综合、归纳与抽象,形成一个独立于具体DBMS的概念模型AnIntroductiontoDatabaseSystem数据库设计的基本步骤(续) ⒊逻辑结构设计阶段将概念结构转换为某个DBMS所支持的数据模型对其进行优化AnIntroductiontoDatabaseSystem数据库设计的基本步骤(续)
⒋数据库物理设计阶段为逻辑数据模型选取一个最适合应用环境的物理结构(包括存储结构和存取方法)AnIntroductiontoDatabaseSystem数据库设计的基本步骤(续)
⒌数据库实施阶段运用DBMS提供的数据库语言(如SQL)及宿主语言,根据逻辑设计和物理设计的结果建立数据库编制与调试应用程序组织数据入库进行试运行AnIntroductiontoDatabaseSystem数据库设计的基本步骤(续)
⒍数据库运行和维护阶段数据库应用系统经过试运行后即可投入正式运行在数据库系统运行过程中必须不断地对其进行评价、调整与修改AnIntroductiontoDatabaseSystem数据库设计的基本步骤应用需求(数据、处理)转换需求、DBMS功能、优化方法应用要求,DBMS详细特征需求收集和分析设计概念结构设计逻辑结构数据模型优化设计物理结构评价设计,性能预测物理实现试验性运行使用、维护数据库不满意不满意需求分析阶段概念设计阶段逻辑设计阶段物理设计阶段数据库实施阶段数据库运行、维护阶段不满意AnIntroductiontoDatabaseSystem数据库设计的基本步骤(续)设计一个完善的数据库应用系统往往是上述六个阶段的不断反复把数据库设计和对数据库中数据处理的设计紧密结合起来将这两个方面的需求分析、抽象、设计、实现在各个阶段同时进行,相互参照,相互补充,以完善两方面的设计AnIntroductiontoDatabaseSystem数据库设计各个阶段的设计描述AnIntroductiontoDatabaseSystem7.1数据库设计概述7.1.1数据库设计的特点7.1.2数据库设计方法7.1.3数据库设计的基本步骤7.1.4数据库设计过程中的各级模式AnIntroductiontoDatabaseSystem7.1.4数据库设计过程中的各级模式数据库设计阶段的模式数据库结构设计的不同阶段形成数据库的各级模式需求分析阶段:综合各个用户的应用需求;概念设计阶段:形成独立于机器特点,独立于各个DBMS产品的概念模式,即E-R图;逻辑设计阶段:将E-R图转换成具体的数据库产品支持的数据模型,如关系模型,形成数据库逻辑模式;然后根据用户处理的要求、安全性的考虑,在基本表的基础上再建立必要的视图,形成数据的外模式;物理设计阶段:根据DBMS特点和处理的需要,进行物理存储安排,建立索引,形成数据库内模式。AnIntroductiontoDatabaseSystem7.1.4数据库设计过程中的各级模式应用要求应用要求概念模式逻辑模式存储模式应用要求综合转换转换外模式外模式外模式应用1应用2应用3映象应用1应用2应用3机器世界模型信息世界模型现实世界需求分析阶段:综合用户应用需求概念设计阶段:形成概念模式,即E-R图;逻辑设计阶段:转换成数据模型,形成数据库逻辑模式;建立必要的视图,形成数据的外模式;物理设计阶段:进行物理存储安排,建立索引,形成数据库内模式。AnIntroductiontoDatabaseSystem第七章数据库设计7.1数据库设计概述7.2需求分析7.3概念结构设计7.4逻辑结构设计7.5数据库的物理设计7.6数据库实施和维护7.7小结AnIntroductiontoDatabaseSystem7.2需求分析7.2.1需求分析的任务7.2.2需求分析的方法7.2.3数据字典AnIntroductiontoDatabaseSystem7.2.1需求分析的任务需求分析的任务需求分析的重点需求分析的难点AnIntroductiontoDatabaseSystem需求分析的任务详细调查现实世界要处理的对象(组织、部门、企业等)充分了解原系统(手工系统或计算机系统)明确用户的各种需求确定新系统的功能充分考虑今后可能的扩充和改变AnIntroductiontoDatabaseSystem需求分析的重点调查的重点是“数据”和“处理”,获得用户对数据库要求
信息要求处理要求安全性与完整性要求AnIntroductiontoDatabaseSystem需求分析的难点确定用户最终需求用户缺少计算机知识设计人员缺少用户的专业知识解决方法设计人员必须不断深入地与用户进行交流AnIntroductiontoDatabaseSystem7.2需求分析7.2.1需求分析的任务7.2.2需求分析的方法7.2.3数据字典AnIntroductiontoDatabaseSystem7.2.2需求分析的方法调查需求达成共识分析表达需求AnIntroductiontoDatabaseSystem调查用户需求的具体步骤⑴调查组织机构情况。⑵调查各部门的业务活动情况。⑶在熟悉业务活动的基础上,协助用户明确对新系统的各种要求。⑷确定新系统的边界。AnIntroductiontoDatabaseSystem常用调查方法(1)跟班作业(2)开调查会(3)请专人介绍(4)询问(5)设计调查表请用户填写(6)查阅记录AnIntroductiontoDatabaseSystem进一步分析和表达用户需求结构化分析方法(StructuredAnalysis,简称SA方法)
从最上层的系统组织机构入手自顶向下、逐层分解分析系统AnIntroductiontoDatabaseSystem进一步分析和表达用户需求(续)1.首先把任何一个系统都抽象为:数据流数据流数据存储信息要求数据来源处理数据输出处理要求AnIntroductiontoDatabaseSystem进一步分析和表达用户需求(续)2.分解处理功能和数据
(1)分解处理功能将处理功能的具体内容分解为若干子功能
(2)分解数据处理功能逐步分解同时,逐级分解所用数据,形成若干层次的数据流图
(3)表达方法处理逻辑:用判定表或判定树来描述数据:用数据字典来描述3.将分析结果再次提交给用户,征得用户的认可AnIntroductiontoDatabaseSystem概念设计阶段需求分析阶段需求分析过程熟悉业务活动明确用户需求确定系统边界分析系统功能分析系统数据编写分析报告调查机构情况数据字典数据流图用户数据库设计人员AnIntroductiontoDatabaseSystem补充:
需求分析结果-数据流图(DFD)数据流图数据流图表达了数据与处理的关系数据流图的基本元素
描述一个处理。输入数据在此进行变换产生输出数据。其中注明处理的名称。
描述一个输入源点或输出汇点。其中注明源点或汇点的名称。
描述一个数据流。被加工的数据及其流向。流线上注明数据流名称,箭头代表数据流动方向。
描述一个数据存储。通常用于代表一个数据表,其中注明数据表的名称。AnIntroductiontoDatabaseSystem补充:
需求分析结果-数据流图数据流图画数据流图的步骤和原则基本步骤:自外向内,自顶向下,逐层细化,完善求精。基本原则:①数据流图上所有图形符号只限于前述四种基本元素。②顶层数据流图必须包括前述四种基本元素,缺一不可。③顶层数据流图上的数据流必须封闭在外部实体之间。④每个加工至少有一个输入数据流和一个输出数据流。AnIntroductiontoDatabaseSystem补充:
需求分析结果-数据流图⑤在数据流图中,需按层给加工框编号。编号表明该加工处在哪一层,以及上下层的父图与子图的对应关系。⑥规定任何一个数据流子图必须与它上一层的一个加工对应,两者的输入数据流和输出数据流必须一致。此即父图与子图的平衡。⑦可以在数据流图中加入物质流,帮助用户理解数据流图。⑧图上每个元素都必须有名字。数据流和数据文件的名字应当是“名词”或“名词性短语”,表明流动的数据是什么。加工的名字应当是“名词+宾语”,表明做什么事情。AnIntroductiontoDatabaseSystem补充:
需求分析结果-数据流图数据流图分层数据流图AnIntroductiontoDatabaseSystem需求分析小结实例:假设我们要开发一个学校管理系统。1.经过可行性分析和初步需求调查,抽象出该系统最高层数据流图,该系统由教师管理子系统、学生管理子系统、后勤管理子系统组成,每个子系统分别配备一个开发小组。2.进一步细化各个子系统。其中学生管理子系统开发小组通过进行进一步的需求调查,明确了该子系统的主要功能是进行学籍管理和课程管理,包括学生报到、入学、毕业的管理,学生上课情况的管理。通过详细的信息流程分析和数据收集后,他们生成了该子系统的数据流图。AnIntroductiontoDatabaseSystem学校信息管理系统AnIntroductiontoDatabaseSystem学籍管理的数据流图AnIntroductiontoDatabaseSystem7.2需求分析7.2.1需求分析的任务7.2.2需求分析的方法7.2.3数据字典AnIntroductiontoDatabaseSystem7.2.3数据字典数据字典的用途进行详细的数据收集和数据分析所获得的主要结果数据字典的内容数据项数据结构数据流数据存储处理过程AnIntroductiontoDatabaseSystem⒈数据项数据项是不可再分的数据单位对数据项的描述
数据项描述={数据项名,数据项含义说明,别名, 数据类型,长度,取值范围,取值含义, 与其他数据项的逻辑关系,数据项之间的 联系}AnIntroductiontoDatabaseSystem⒉数据结构数据结构反映了数据之间的组合关系。一个数据结构可以由若干个数据项组成,也可以由若干个数据结构组成,或由若干个数据项和数据结构混合组成。对数据结构的描述
数据结构描述={数据结构名,含义说明,组成:{数据项或数据结构}}AnIntroductiontoDatabaseSystem⒊数据流数据流是数据结构在系统内传输的路径。对数据流的描述
数据流描述={数据流名,说明,数据流来源,数据流去向,组成:{数据结构},平均流量,高峰期流量}AnIntroductiontoDatabaseSystem⒋数据存储数据存储是数据结构停留或保存的地方,也是数据流的来源和去向之一。对数据存储的描述
数据存储描述={数据存储名,说明,编号, 输入的数据流,输出的数据流, 组成:{数据结构},数据量,存取频度, 存取方式}AnIntroductiontoDatabaseSystem⒌处理过程具体处理逻辑一般用判定表或判定树来描述。处理过程说明性信息的描述
处理过程描述={处理过程名,说明,输入:{数据流},输出:{数据流},处理:{简要说明}}AnIntroductiontoDatabaseSystem数据字典举例例:学生学籍管理子系统的数据字典。数据项:以“学号”为例:数据项:学号含义说明:唯一标识每个学生别名:学生编号类型:字符型长度:8
取值范围:00000000至99999999取值含义:前两位标别该学生所在年级,后六位按顺序编号与其他数据项的逻辑关系:AnIntroductiontoDatabaseSystem处理过程(续) 数据结构:以“学生”为例 “学生”是该系统中的一个核心数据结构:数据结构:学生含义说明:是学籍管理子系统的主体数据结构,定义了一个学生的有关信息组成:学号,姓名,性别,年龄,所在系,年级
AnIntroductiontoDatabaseSystem处理过程(续)数据流:“体检结果”可如下描述:数据流:体检结果说明:学生参加体格检查的最终结果数据流来源:体检数据流去向:批准组成:……平均流量:……高峰期流量:……AnIntroductiontoDatabaseSystem处理过程(续)数据存储:“学生登记表”可如下描述:数据存储:学生登记表说明:记录学生的基本情况流入数据流:……
流出数据流:……
组成:……
数据量:每年3000张存取方式:随机存取
AnIntroductiontoDatabaseSystem处理过程(续)处理过程:“分配宿舍”可如下描述:处理过程:分配宿舍说明:为所有新生分配学生宿舍输入:学生,宿舍输出:宿舍安排处理:在新生报到后,为所有新生分配学生宿舍。要求同一间宿舍只能安排同一性别的学生,同一个学生只能安排在一个宿舍中。每个学生的居住面积不小于3平方米。安排新生宿舍其处理时间应不超过15分钟。
AnIntroductiontoDatabaseSystem需求分析结果-数据字典
数据字典举例①数据项:以“学号”为例数据项名:学号数据项含义:唯一标识每一个学生别名:学生编号数据类型:字符型长度:8取值范围:00000~99999取值含义:前2位为入学年号,后3位为顺序编号与其他数据项的逻辑关系:(无)AnIntrod
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 医学资料 早产儿护理查房文稿 学习课件
- 计算机二级复习资料及试题及答案
- 山东省海洋知识竞赛(小学生组)考试题(附答案)
- 供应室岗前培训
- 《十六年前的回忆》教学设计【9篇】
- 《2025关于两企业之间设备《采购合同》的意见书》
- 小肠溃疡的健康宣教
- 初中语文课外古诗文夏本纪全文阅读及翻译
- 产品加工定制合同标准文本
- 2手房屋转让合同范例
- 上海七年级数学下期末(压轴60题16个考点)分析版
- 教学能力比赛学情分析图(源图可编辑)
- 2024届上海市南汇区英语四年级第二学期期中调研试题含答案
- 《全面系统企业微信使用教程课件》
- 科目三新规教学大纲
- 住院医师规范化培训临床实践能力考核考官选派条件和主要职责
- 人教版数学八年级上学期《三角形》单元检测题(附答案)
- 初中数学-图形的平移教学设计学情分析教材分析课后反思
- 兰州交通大学《C语言程序设计》2016-2017学年期末试卷
- 心电图考试题及答案
- 质量管理的标准管理规程SMP
评论
0/150
提交评论