《[精选]数据库的物理设计、实施和维护31000.pptx》由会员分享,可在线阅读,更多相关《[精选]数据库的物理设计、实施和维护31000.pptx(92页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、数据库系统概论数据库系统概论An Introduction to Database System第七章第七章 数据库设计数据库设计(续续2)2)电子信息学院电子信息学院 殷伟凤殷伟凤An Introduction to Database System第七章第七章 数据库设计数据库设计7.1 数据库设计概述数据库设计概述7.2 需求分析需求分析7.3 概念结构设计概念结构设计7.4 逻辑结构设计逻辑结构设计7.5 数据库的物理设计数据库的物理设计7.6 数据库的实施和维护数据库的实施和维护7.7 小结小结An Introduction to Database System7.4 逻辑结构设计逻辑
2、结构设计v逻辑结构设计的任务把概念结构设计阶段设计好的基本E-R图转换为与选用DBMS产品所支持的数据模型相符合的逻辑结构An Introduction to Database System7.4 逻辑结构设计逻辑结构设计7.4.1 E-R图向关系模型的转换图向关系模型的转换7.4.2 数据模型的优化数据模型的优化7.4.3 设计用户子模式设计用户子模式An Introduction to Database System7.4.1 E-R图向关系模型的转换图向关系模型的转换vE-R图向关系模型的转换要解决的问题 如何将实体型和实体间的联系转换为关系模式如何确定这些关系模式的属性和码 v转换内容
3、将E-R图转换为关系模型:将实体、实体的属性和实体之间的联系转换为关系模式。An Introduction to Database SystemE-R图向关系模型的转换(续)图向关系模型的转换(续)实体型间的联系有以下不同情况:(1)一个1:1联系可以转换为一个独立的关系模式,也可以与任意一端对应的关系模式合并。转换为一个独立的关系模式 与某一端实体对应的关系模式合并(2)一个1:n联系可以转换为一个独立的关系模式,也可以与n端对应的关系模式合并。转换为一个独立的关系模式与n端对应的关系模式合并An Introduction to Database SystemE-R图向关系模型的转换(续)图
4、向关系模型的转换(续)(3)一个m:n联系转换为一个关系模式。例,“选修”联系是一个m:n联系,可以将它转换为如下关系模式,其中学号与课程号为关系的组合码:选修(学号,课程号,成绩)An Introduction to Database SystemE-R图向关系模型的转换(续)图向关系模型的转换(续)(4)三个或三个以上实体间的一个多元联系转换为一个关系模式。例,“讲授”联系是一个三元联系,可以将它转换为如下关系模式,其中课程号、职工号和书号为关系的组合码:讲授(课程号,职工号,书号)An Introduction to Database SystemE-R图向关系模型的转换(续)图向关系模
5、型的转换(续)(5)具有相同码的关系模式可合并目的:减少系统中的关系个数合并方法:将其中一个关系模式的全部属性加入到另一个关系模式中,然后去掉其中的同义属性(可能同名也可能不同名),并适当调整属性的次序An Introduction to Database SystemE-R图向关系模型的转换(续)图向关系模型的转换(续)注意:v从理论上讲,1:1联系可以与任意一端对应的关系模式合并v但在一些情况下,与不同的关系模式合并效率会大不一样。因此究竟应该与哪端的关系模式合并需要依应用的具体情况而定。v由于连接操作是最费时的操作,所以一般应以尽量减少连接操作为目标。例如,如果经常要查询某个班级的班主任
6、姓名,则将管理联系与教师关系合并更好些。An Introduction to Database SystemE-R图向关系模型的转换(续)图向关系模型的转换(续)例 把图7.30中虚线上部的E-R图转换为关系模型 部门实体对应的关系模式 部门(部门号,部门名,经理的职工号,)此关系模式已包含了联系“领导”所对应的关系模式 经理的职工号是关系的候选码 职工实体对应的关系模式 职工(职工号、部门号,职工名,职务,)该关系模式已包含了联系“属于”所对应的关系模式 An Introduction to Database SystemE-R图向关系模型的转换(续)图向关系模型的转换(续)例 把图7.30
7、中虚线上部的E-R图转换为关系模型(续)产品实体对应的关系模式 产品(产品号,产品名,产品组长的职工号,)供应商实体对应的关系模式 供应商(供应商号,姓名,)零件实体对应的关系模式 零件(零件号,零件名,)An Introduction to Database SystemE-R图向关系模型的转换(续)图向关系模型的转换(续)例 把图7.30中虚线上部的E-R图转换为关系模型(续)联系“参加”所对应的关系模式 职工工作(职工号,产品号,工作天数,)联系“供应”所对应的关系模式 供应(产品号,供应商号,零件号,供应量)An Introduction to Database System教学管理的
8、教学管理的ER图图系编号系编号系名系名电话电话系系教师教师课程课程教工号教工号姓名姓名性别性别职称职称教材教材课程号课程号课程课程学分学分聘期聘期主管主管聘用聘用开设开设任教任教MN1111NNAn Introduction to Database SystemER图到关系模式的转换图到关系模式的转换v图中,有三个实体类型:系、教师和课程;v有4个联系类型:主管、聘用、开设和任教。v第一步:v把3个实体类型转换称3个模式:v系(系编号,系名,电话)v教师(教工号,姓名,性别,职称)v课程(课程号,课程名,学分)v第二步:v对于1:1联系“主管”。可以在“系”模式中加入教工号(教工号为外键)An
9、 Introduction to Database SystemER图到关系模式的转换图到关系模式的转换v对于1:N联系“聘用”,可以在“教师”模式中加入系编号和聘期两个属性(系编号为外键)。v对与1:N联系“开设”,可以在“课程”模式中加入系编号(系编号为外键)。这样第一步得到的3个模式为:v系(系编号,系名,电话,主管人的教工号)v教师(教工号,姓名,性别,职称,系编号,聘期)v课程(课程号,课程名,学分,系编号)An Introduction to Database Systemv第三步:v对于M:N联系“任教”,则生成一个新的关系模式:v任教(教工号,课程号,教材)v这样,转换成的4个
10、关系模式如下:v系(系编号,系名,电话,主管人的教工号)v教师(教工号,姓名,性别,职称,系编号,聘期)v课程(课程号,课程名,学分,系编号)v任教(教工号,课程号,教材)ER图到关系模式的转换图到关系模式的转换An Introduction to Database System7.4 逻辑结构设计逻辑结构设计7.4.1 E-R图向关系模型的转换图向关系模型的转换7.4.2 数据模型的优化数据模型的优化7.4.3 设计用户子模式设计用户子模式An Introduction to Database System7.4.2 数据模型的优化数据模型的优化v得到初步数据模型后,还应该适当地修改、调整数
11、据模型的结构,以进一步提高数据库应用系统的性能,这就是数据模型的优化v关系数据模型的优化通常以规范化理论为指导An Introduction to Database System数据模型的优化(续)数据模型的优化(续)v优化数据模型的方法1.确定数据依赖2.按需求分析阶段所得到的语义,分别写出每个关系模式内部各属性之间的数据依赖以及不同关系模式属性之间数据依赖2.消除 冗余的联系3.对于各个关系模式之间的数据依赖进行极小化处理,消除 冗余的联系。An Introduction to Database System数据模型的优化(续)数据模型的优化(续)3.确定所属范式按照数据依赖的理论对关系模
12、式逐一进行分析考查是否存在部分函数依赖、传递函数依赖、多值依赖等确定各关系模式分别属于第几范式4.按照需求分析阶段得到的各种应用对数据处理的要求,分析对于这样的应用环境这些模式是否合适,5.确定是否要对它们进行合并或分解。6.6.注意:注意:注意:注意:并不是规范化程度越高的关系就越优,一般说来,第三范式就足够了An Introduction to Database System数据模型的优化(续)数据模型的优化(续)例:在关系模式 学生成绩单(学号,英语,数学,语文,平均成绩)中存在下列函数依赖:学号英语 学号数学 学号语文 学号平均成绩 (英语,数学,语文)平均成绩An Introduct
13、ion to Database System数据模型的优化(续)数据模型的优化(续)显然有:学号(英语,数学,语文)因此该关系模式中存在传递函数信赖,是2NF关系 虽然平均成绩可以由其他属性推算出来,但如果应用中需要经常查询学生的平均成绩,为提高效率,仍然可保留该冗余数据,对关系模式不再做进一步分解An Introduction to Database System数据模型的优化(续)数据模型的优化(续)5.按照需求分析阶段得到的各种应用对数据处理的要求,对关系模式进行必要的分解,以提高数据操作的效率和存储空间的利用率常用分解方法水平分解垂直分解An Introduction to Datab
14、ase System数据模型的优化(续)数据模型的优化(续)水平分解什么是水平分解把(基本)关系的元组分为若干子集合,定义每个子集合为一个子关系,以提高系统的效率水平分解的适用范围满足“80/20原则”的应用并发事务经常存取不相交的数据An Introduction to Database System数据模型的优化(续)数据模型的优化(续)垂直分解什么是垂直分解把关系模式R的属性分解为若干子集合,形成若干子关系模式垂直分解的适用范围取决于分解后R上的所有事务的总效率是否得到了提高An Introduction to Database System7.4 逻辑结构设计逻辑结构设计7.4.1 E
15、-R图向关系模型的转换图向关系模型的转换7.4.2 数据模型的优化数据模型的优化7.4.3 设计用户子模式设计用户子模式An Introduction to Database System7.4.3 设计用户子模式设计用户子模式v定义用户外模式时应该注重的问题 包括三个方面:(1)使用更符合用户习惯的别名 (2)针对不同级别的用户定义不同的View,以 满足系统对安全性的要求。(3)简化用户对系统的使用An Introduction to Database System设计用户子模式(续)设计用户子模式(续)例例 关系模式产品(产品号,产品名,规格,单价,生产车间,生产负责人,产品成本,产品合
16、格率,质量等级),可以在产品关系上建立两个视图:为一般顾客建立视图:产品1(产品号,产品名,规格,单价)为产品销售部门建立视图:产品2(产品号,产品名,规格,单价,车间,生产负责人)顾客视图中只包含允许顾客查询的属性销售部门视图中只包含允许销售部门查询的属性生产领导部门则可以查询全部产品数据可以防止用户非法访问不允许他们查询的数据,保证系统的安全性An Introduction to Database System逻辑结构设计小结逻辑结构设计小结v任务将概念结构转化为具体的数据模型v逻辑结构设计的步骤将概念结构转化为一般的关系、网状、层次模型将转化来的关系、网状、层次模型向特定DBMS支持下的
17、数据模型转换对数据模型进行优化设计用户子模式An Introduction to Database System逻辑结构设计小结逻辑结构设计小结vE-R图向关系模型的转换内容vE-R图向关系模型的转换原则An Introduction to Database System逻辑结构设计小结逻辑结构设计小结v优化数据模型的方法 1.确定数据依赖 2.对于各个关系模式之间的数据依赖进行极小化处理,消除冗余的联系。3.确定各关系模式分别属于第几范式。4.分析对于应用环境这些模式是否合适,确定是否要对它们进行合并或分解。5.对关系模式进行必要的分解或合并An Introduction to Databa
18、se System逻辑结构设计小结逻辑结构设计小结v设计用户子模式 1.使用更符合用户习惯的别名 2.针对不同级别的用户定义不同的外模式,以满足系统对安全性的要求。3.简化用户对系统的使用An Introduction to Database System举例举例v某公司需建立产品信息数据库,经调查其业务要求如下:v1、一种产品可以使用多个不同种类的部件,也可以使用多个不同种类的零件;一种部件至少被用在一种产品中;一种部件可以由多个不同种类的零件组成;一种零件至少被用在一种产品或一种部件中;v2、对于一种具体的部件,要记录这种部件使用的各种零件的数量;v3、对于一种具体的产品,要记录这种产品使
19、用的各种部件数量和各种零件数量,但部件所使用的零件数量不计入该种产品的零件数量;v4、一个供应商可供应多种零件,但一种零件只能由一个供应商供应。An Introduction to Database System根据以上业务要求,某建模人员构建了如下根据以上业务要求,某建模人员构建了如下ER图图产品号产品号产品名称产品名称型号型号装配图号装配图号产品产品产品产品-部件部件部件部件部件号部件号部件名称部件名称部件部件-零件零件零件零件零件号零件号零件名称零件名称联系电话联系电话供应商名供应商名供应商号供应商号mnnm此此ER图中的实体的属性完整,但实体、联系的设计存在不合理之处。图中的实体的属性
20、完整,但实体、联系的设计存在不合理之处。(1)请重新构建合理的)请重新构建合理的ER图,使之符合业务要求,且信息完整。图,使之符合业务要求,且信息完整。(2)根据重构的根据重构的ER图给出符合图给出符合3NF的关系模式,并标出每个关系模式的主码和外码。的关系模式,并标出每个关系模式的主码和外码。An Introduction to Database System重构重构ER图图产品号产品号产品名称产品名称型号型号装配图号装配图号产品产品产品产品-部件部件部件部件部件号部件号部件名称部件名称部件部件-零件零件零件零件零件号零件号零件名称零件名称联系电话联系电话供应商名供应商名供应商号供应商号mn
21、nm产品产品-零件零件nm数量数量数量数量数量数量供应商供应商供应商号供应商号供应商名供应商名1n联系电话联系电话An Introduction to Database System整理后的整理后的ER图图产品产品产品产品-部件部件部件部件部件部件-零件零件零件零件mnnm产品号产品号产品名称产品名称型号型号装配图号装配图号产品产品-零件零件nm部件号部件号部件名称部件名称数量数量数量数量数量数量供应商供应商供应商号供应商号供应商名供应商名1n联系电话联系电话型号型号零件号零件号零件名称零件名称An Introduction to Database System符合符合3NF的关系模式的关系模
22、式v产品(产品号(PK),产品名称,型号,装配图号)v部件(部件号(PK),部件名称)v零件(零件号(PK),零件名称,供应商号(FK)v产品_部件(产品号(FK),部件号(FK),部件数量)v产品_零件(产品号(FK),零件号(FK),零件数量)v部件_零件(部件号(FK),零件号(FK),零件数量)v供应商(供应商号(PK),供应商名称,联系电话)An Introduction to Database System作业作业 P234(19)An Introduction to Database System第七章第七章 数据库设计数据库设计7.1 数据库设计概述数据库设计概述7.2 需求分
23、析需求分析7.3 概念结构设计概念结构设计7.4 逻辑结构设计逻辑结构设计7.5 数据库的物理设计数据库的物理设计7.6 数据库的实施和维护数据库的实施和维护7.7 小结小结An Introduction to Database System7.5 数据库的物理设计数据库的物理设计v数据库的物理设计数据库在物理设备上的存储结构与存取方法称为数据库的物理结构,它依赖于选定的数据库管理系统为一个给定的逻辑数据模型选取一个最适合应用环境的物理结构的过程,就是数据库的物理设计An Introduction to Database System数据库的物理设计数据库的物理设计(续续)v数据库物理设计的步
24、骤确定数据库的物理结构,在关系数据库中主要指存取方法和存储结构 对物理结构进行评价,评价的重点是时间和空间效率 如果评价结果满足原设计要求,则可进入到物理实施阶段,否则,就需要重新设计或修改物理结构,有时甚至要返回逻辑设计阶段修改数据模型An Introduction to Database System数据库的物理设计数据库的物理设计(续续)数据库物理设计数据库物理设计确定数确定数据库的据库的物理结物理结构构评价数据评价数据库的物理库的物理结构结构逻辑结逻辑结构设计构设计数据库数据库实施实施物理物理模型模型逻辑逻辑模型模型An Introduction to Database System7
25、.5 数据库的物理设计数据库的物理设计7.5.1 数据库物理设计的内容和方法数据库物理设计的内容和方法7.5.2 关系模式存取方法选择关系模式存取方法选择7.5.3 确定数据库的存储结构确定数据库的存储结构7.5.4 评价物理结构评价物理结构An Introduction to Database System7.5.1 数据库物理设计的内容和方法数据库物理设计的内容和方法v设计物理数据库结构的准备工作对要运行的事务进行详细分析,获得选择物理数据库设计所需参数充分了解所用RDBMS的内部特征,特别是系统提供的存取方法和存储结构An Introduction to Database System数
26、据库的物理设计的内容和方法(续)数据库的物理设计的内容和方法(续)v选择物理数据库设计所需参数 数据库查询事务查询的关系 查询条件所涉及的属性 连接条件所涉及的属性 查询的投影属性 An Introduction to Database System数据库的物理设计的内容和方法(续)数据库的物理设计的内容和方法(续)v选择物理数据库设计所需参数(续)数据更新事务被更新的关系每个关系上的更新操作条件所涉及的属性 修改操作要改变的属性值 每个事务在各关系上运行的频率和性能要求An Introduction to Database System数据库的物理设计的内容和方法(续)数据库的物理设计的内容
27、和方法(续)v关系数据库物理设计的内容为关系模式选择存取方法(建立存取路径)设计关系、索引等数据库文件的物理存储结构An Introduction to Database System7.5 数据库的物理设计数据库的物理设计7.5.1 数据库物理设计的内容和方法数据库物理设计的内容和方法7.5.2 关系模式存取方法选择关系模式存取方法选择7.5.3 确定数据库的存储结构确定数据库的存储结构7.5.4 评价物理结构评价物理结构An Introduction to Database System7.5.2 关系模式存取方法选择关系模式存取方法选择v数据库系统是多用户共享的系统,对同一个关系要建立多
28、条存取路径才能满足多用户的多种应用要求v物理设计的任务之一就是要确定选择哪些存取方法,即建立哪些存取路径An Introduction to Database System关系模式存取方法选择(续)关系模式存取方法选择(续)vDBMS常用存取方法索引方法目前主要是B+树索引方法经典存取方法,使用最普遍 聚簇(Cluster)方法HASH方法An Introduction to Database System一、索引存取方法的选择一、索引存取方法的选择v根据应用要求确定 对哪些属性列建立索引 对哪些属性列建立组合索引 对哪些索引要设计为唯一索引An Introduction to Databas
29、e System索引存取方法的选择(续)索引存取方法的选择(续)v选择索引存取方法的一般规则如果一个(或一组)属性经常在查询条件中出现,则考虑在这个(或这组)属性上建立索引(或组合索引)如果一个属性经常作为最大值和最小值等聚集函数的参数,则考虑在这个属性上建立索引如果一个(或一组)属性经常在连接操作的连接条件中出现,则考虑在这个(或这组)属性上建立索引v关系上定义的索引数过多会带来较多的额外开销 维护索引的开销 查找索引的开销An Introduction to Database System二、聚簇存取方法的选择二、聚簇存取方法的选择v聚簇为了提高某个属性(或属性组)的查询速度,把这个或这些
30、属性(称为聚簇码)上具有相同值的元组集中存放在连续的物理块称为聚簇An Introduction to Database System聚簇存取方法的选择(续)聚簇存取方法的选择(续)v聚簇的用途1.大大提高按聚簇码进行查询的效率 例:假设学生关系按所在系建有索引,现在要查询信息系的所有学生名单。信息系的500名学生分布在500个不同的物理块上时,至少要执行500次I/O操作如果将同一系的学生元组集中存放,则每读一个物理块可得到多个满足查询条件的元组,从而显著地减少了访问磁盘的次数An Introduction to Database System聚簇存取方法的选择(续)聚簇存取方法的选择(续)
31、2.节省存储空间聚簇以后,聚簇码相同的元组集中在一起了,因而聚簇码值不必在每个元组中重复存储,只要在一组中存一次就行了An Introduction to Database System聚簇存取方法的选择(续)聚簇存取方法的选择(续)v聚簇的局限性1.聚簇只能提高某些特定应用的性能2.建立与维护聚簇的开销相当大对已有关系建立聚簇,将导致关系中元组移动其物理存储位置,并使此关系上原有的索引无效,必须重建当一个元组的聚簇码改变时,该元组的存储位置也要做相应移动An Introduction to Database System聚簇存取方法的选择(续)聚簇存取方法的选择(续)v聚簇的适用范围1.既适
32、用于单个关系独立聚簇,也适用于多个关系组合聚簇例:假设用户经常要按系别查询学生成绩单,这一查询涉及学生关系和选修关系的连接操作,即需要按学号连接这两个关系,为提高连接操作的效率,可以把具有相同学号值的学生元组和选修元组在物理上聚簇在一起。这就相当于把多个关系按“预连接”的形式存放,从而大大提高连接操作的效率。An Introduction to Database System聚簇存取方法的选择(续)聚簇存取方法的选择(续)2.当通过聚簇码进行访问或连接是该关系的主要应用,与聚簇码无关的其他访问很少或者是次要的时,可以使用聚簇。尤其当SQL语句中包含有与聚簇码有关的ORDER BY,GROUP
33、BY,UNION,DISTINCT等子句或短语时,使用聚簇特别有利,可以省去对结果集的排序操作An Introduction to Database System聚簇存取方法的选择(续)聚簇存取方法的选择(续)v设计候选聚簇对经常在一起进行连接操作的关系可以建立聚簇如果一个关系的一组属性经常出现在相等比较条件中,则该单个关系可建立聚簇如果一个关系的一个(或一组)属性上的值重复率很高,则此单个关系可建立聚簇。即对应每个聚簇码值的平均元组数不太少。太少了,聚簇的效果不明显An Introduction to Database System聚簇存取方法的选择(续)聚簇存取方法的选择(续)v优化聚簇设
34、计从聚簇中删除经常进行全表扫描的关系;从聚簇中删除更新操作远多于连接操作的关系;不同的聚簇中可能包含相同的关系,一个关系可以在某一个聚簇中,但不能同时加入多个聚簇 从这多个聚簇方案(包括不建立聚簇)中选择一个较优的,即在这个聚簇上运行各种事务的总代价最小An Introduction to Database System三、三、HASH存取方法的选择存取方法的选择v选择HASH存取方法的规则当一个关系满足下列两个条件时,可以选择HASH存取方法该关系的属性主要出现在等值连接条件中或主要出现在相等比较选择条件中该关系的大小可预知,而且不变;或 该关系的大小动态改变,但所选用的DBMS提供了动态H
35、ASH存取方法An Introduction to Database System7.5 数据库的物理设计数据库的物理设计7.5.1 数据库物理设计的内容和方法数据库物理设计的内容和方法7.5.2 关系模式存取方法选择关系模式存取方法选择7.5.3 确定数据库的存储结构确定数据库的存储结构7.5.4 评价物理结构评价物理结构An Introduction to Database System7.5.3 确定数据库的存储结构确定数据库的存储结构v确定数据库物理结构的内容1.确定数据的存放位置和存储结构 关系 索引 聚簇 日志 备份2.确定系统配置An Introduction to Databa
36、se System1.确定数据的存放位置确定数据的存放位置v确定数据存放位置和存储结构的因素存取时间存储空间利用率维护代价 这三个方面常常是相互矛盾的 例:消除一切冗余数据虽能够节约存储空间和减少维护代价,但往往会导致检索代价的增加 必须进行权衡,选择一个折中方案An Introduction to Database System确定数据的存放位置(续)确定数据的存放位置(续)v基本原则根据应用情况将易变部分与稳定部分分开存放存取频率较高部分与存取频率较低部分,分开存放An Introduction to Database System确定数据的存放位置(续)确定数据的存放位置(续)例:数据库
37、数据备份、日志文件备份等由于只在故障恢复时才使用,而且数据量很大,可以考虑存放在磁带上如果计算机有多个磁盘或磁盘阵列,可以考虑将表和索引分别放在不同的磁盘上,在查询时,由于磁盘驱动器并行工作,可以提高物理I/O读写的效率 An Introduction to Database System确定数据的存放位置(续)确定数据的存放位置(续)例(续):可以将比较大的表分别放在两个磁盘上,以加快存取速度,这在多用户环境下特别有效可以将日志文件与数据库对象(表、索引等)放在不同的磁盘以改进系统的性能An Introduction to Database System2.确定系统配置确定系统配置vDBMS
38、产品一般都提供了一些存储分配参数 同时使用数据库的用户数 同时打开的数据库对象数 内存分配参数 使用的缓冲区长度、个数 存储分配参数 .An Introduction to Database System7.5 数据库的物理设计数据库的物理设计7.5.1 数据库物理设计的内容和方法数据库物理设计的内容和方法7.5.2 关系模式存取方法选择关系模式存取方法选择7.5.3 确定数据库的存储结构确定数据库的存储结构7.5.4 评价物理结构评价物理结构An Introduction to Database System7.5.4 评价物理结构评价物理结构v评价内容对数据库物理设计过程中产生的多种方案进
39、行细致的评价,从中选择一个较优的方案作为数据库的物理结构An Introduction to Database System评价物理结构评价物理结构(续续)v评价方法(完全依赖于所选用的DBMS)定量估算各种方案 存储空间 存取时间 维护代价对估算结果进行权衡、比较,选择出一个较优的合理的物理结构如果该结构不符合用户需求,则需要修改设计An Introduction to Database System第七章第七章 数据库设计数据库设计7.1 数据库设计概述数据库设计概述7.2 需求分析需求分析7.3 概念结构设计概念结构设计7.4 逻辑结构设计逻辑结构设计7.5 数据库的物理设计数据库的物理
40、设计7.6 数据库的实施和维护数据库的实施和维护7.7 小结小结An Introduction to Database System7.6数据库实施和维护数据库实施和维护7.6.1 数据的载入和应用程序的调试数据的载入和应用程序的调试7.6.2 数据库的试运行数据库的试运行 7.6.3 数据库的运行和维护数据库的运行和维护 An Introduction to Database System7.6.1 数据的载入和应用程序的调试数据的载入和应用程序的调试v 数据的载入 v 应用程序的编码和调试An Introduction to Database System 数据的载入数据的载入 v数据库结
41、构建立好后,就可以向数据库中装载数据了。组织数据入库是数据库实施阶段最主要的工作。v数据装载方法人工方法计算机辅助数据入库An Introduction to Database System应用程序的编码和调试应用程序的编码和调试v数据库应用程序的设计应该与数据设计并行进行v在组织数据入库的同时还要调试应用程序 An Introduction to Database System7.6数据库实施和维护数据库实施和维护7.6.1 数据的载入和应用程序的调试数据的载入和应用程序的调试7.6.2 数据库的试运行数据库的试运行 7.6.3 数据库的运行和维护数据库的运行和维护 An Introduct
42、ion to Database System7.6.2 数据库的试运行数据库的试运行v在原有系统的数据有一小部分已输入数据库后,就可以开始对数据库系统进行联合调试,称为数据库的试运行 v数据库试运行主要工作包括:1)功能测试实际运行数据库应用程序,执行对数据库的各种操作,测试应用程序的功能是否满足设计要求 如果不满足,对应用程序部分则要修改、调整,直到达到设计要求2)性能测试测量系统的性能指标,分析是否达到设计目标如果测试的结果与设计目标不符,则要返回物理设计阶段,重新调整物理结构,修改系统参数,某些情况下甚至要返回逻辑设计阶段,修改逻辑结构 An Introduction to Databa
43、se System数据库的试运行(续)数据库的试运行(续)强调两点:v分期分批组织数据入库 重新设计物理结构甚至逻辑结构,会导致数据重新入库。由于数据入库工作量实在太大,费时、费力,所以应分期分批地组织数据入库先输入小批量数据供调试用待试运行基本合格后再大批量输入数据逐步增加数据量,逐步完成运行评价An Introduction to Database System数据库的试运行(续)数据库的试运行(续)v数据库的转储和恢复在数据库试运行阶段,系统还不稳定,硬、软件故障随时都可能发生系统的操作人员对新系统还不熟悉,误操作也不可避免因此必须做好数据库的转储和恢复工作,尽量减少对数据库的破坏。An
44、 Introduction to Database System7.6数据库实施和维护数据库实施和维护7.6.1 数据的载入和应用程序的调试数据的载入和应用程序的调试7.6.2 数据库的试运行数据库的试运行 7.6.3 数据库的运行和维护数据库的运行和维护 An Introduction to Database System7.6.3 数据库的运行与维护数据库的运行与维护v数据库试运行合格后,数据库即可投入正式运行。v数据库投入运行标志着开发任务的基本完成和维护工作的开始v对数据库设计进行评价、调整、修改等维护工作是一个长期的任务,也是设计工作的继续和提高。应用环境在不断变化数据库运行过程中物
45、理存储会不断变化An Introduction to Database System数据库的运行与维护(续)数据库的运行与维护(续)v在数据库运行阶段,对数据库经常性的维护工作主要是由DBA完成的,包括:1.数据库的转储和恢复2.数据库的安全性、完整性控制3.数据库性能的监督、分析和改进4.数据库的重组织和重构造An Introduction to Database System数据库的运行与维护(续)数据库的运行与维护(续)v数据库的重组织和重构造重组织的形式全部重组织部分重组织只对频繁增、删的表进行重组织重组织的目标提高系统性能An Introduction to Database Sys
46、tem数据库的运行与维护(续)数据库的运行与维护(续)重组织的工作按原设计要求重新安排存储位置回收垃圾减少指针链数据库的重组织不会改变原设计的数据逻辑结构和物理结构An Introduction to Database System数据库运行与维护(续)数据库运行与维护(续)数据库重构造根据新环境调整数据库的模式和内模式增加新的数据项改变数据项的类型改变数据库的容量增加或删除索引修改完整性约束条件An Introduction to Database System第七章第七章 数据库设计数据库设计7.1 数据库设计概述数据库设计概述7.2 需求分析需求分析7.3 概念结构设计概念结构设计7.4
47、 逻辑结构设计逻辑结构设计7.5 数据库的物理设计数据库的物理设计7.6 数据库的实施和维护数据库的实施和维护7.7 小结小结An Introduction to Database System7.7 小结小结v数据库的设计过程需求分析概念结构设计逻辑结构设计物理设计实施和维护An Introduction to Database System小结(续)小结(续)v数据库各级模式的形成数据库的各级模式是在设计过程中逐步形成的需求分析阶段综合各个用户的应用需求(现实世界的需求)概念设计阶段形成独立于机器特点、独立于各个DBMS产品的概念模式(信息世界模型),用E-R图来描述An Introduc
48、tion to Database System小结(续)小结(续)在逻辑设计阶段将E-R图转换成具体的数据库产品支持的数据模型如关系模型,形成数据库逻辑模式。然后根据用户处理的要求,安全性的考虑,在基本表的基础上再建立必要的视图(VIEW)形成数据的外模式在物理设计阶段根据DBMS特点和处理的需要,进行物理存储安排,设计索引,形成数据库内模式An Introduction to Database System9、静夜四无邻,荒居旧业贫。3月-233月-23Friday,March 17,202310、雨中黄叶树,灯下白头人。16:57:2916:57:2916:573/17/2023 4:57
49、:29 PM11、以我独沈久,愧君相见频。3月-2316:57:2916:57Mar-2317-Mar-2312、故人江海别,几度隔山川。16:57:2916:57:2916:57Friday,March 17,202313、乍见翻疑梦,相悲各问年。3月-233月-2316:57:2916:57:29March 17,202314、他乡生白发,旧国见青山。17 三月 20234:57:29 下午16:57:293月-2315、比不了得就不比,得不到的就不要。三月 234:57 下午3月-2316:57March 17,202316、行动出成果,工作出财富。2023/3/17 16:57:301
50、6:57:3017 March 202317、做前,能够环视四周;做时,你只能或者最好沿着以脚为起点的射线向前。4:57:30 下午4:57 下午16:57:303月-239、没有失败,只有暂时停止成功!。3月-233月-23Friday,March 17,202310、很多事情努力了未必有结果,但是不努力却什么改变也没有。16:57:3016:57:3016:573/17/2023 4:57:30 PM11、成功就是日复一日那一点点小小努力的积累。3月-2316:57:3016:57Mar-2317-Mar-2312、世间成事,不求其绝对圆满,留一份不足,可得无限完美。16:57:3016: