第七章 关系数据库理论_第1页
第七章 关系数据库理论_第2页
第七章 关系数据库理论_第3页
第七章 关系数据库理论_第4页
第七章 关系数据库理论_第5页
已阅读5页,还剩30页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、本章教学目标、重点和难点,1. 本章教学目标:使学生了解关系模式规范化的必要性,理解函数依赖、多值依赖及其关系范式定义,掌握关系范式判断方法。 2. 教学重点:关系模式规范化,函数依赖、多值依赖、1-4NF的定义,关系范式判断方法。 3. 教学难点:1-4NF的定义,关系范式判断方法。,关系模式规范化的提出,1. 范式(Normal Form)是指规范化的关系模式。 2. 由满足最基本规范化的关系模式叫第一范式,第一范式的关系模式再满足另外一些约束条件就产生了第二范式、第三范式、BC范式等等。 3. 一个低一级的关系范式通过模式分解可以转换成若干高一级范式的关系模式的集合,这种过程叫关系模式的

2、规范化。,关系模式规范化的提出,要求设计教学管理数据库,其关系模式SCD如下: SCD(SNO,SN,AGE,DEPT,MN,CNO,SCORE) 其中,SNO表示学生学号,SN表示学生姓名,AGE表示学生年龄,DEPT表示学生所在的系别,MN表示系主任姓名,CNO表示课程号,SCORE表示成绩。,关系模式规范化的提出,根据实际情况,这些数据有如下语义规定: 1. 一个系有若干个学生,但一个学生只属于一个系; 2. 一个系只有一名系主任,但一个系主任可以同时兼几个系的系主任; 3. 一个学生可以选修多门功课,每门课程可有若干学生选修; 4. 每个学生学习课程有一个成绩。 在此关系模式中填入一部

3、分具体的数据,则可得到SCD关系模式的实例,即一个教学管理数据库,如图所示。,关系模式规范化的提出,关系模式规范化的提出,根据上述的语义规定,并分析以上关系中的数据,我们可以看出:(SNO,CNO)属性的组合能唯一标识一个元组,所以(SNO,CNO)是该关系模式的主关系键。但在进行数据库的操作时,会出现以下几方面的问题。 1. 数据冗余。每个系名和系主任的名字存储的次数等于该系的学生人数乘以每个学生选修的课程门数,同时学生的姓名、年龄也都要重复存储多次,数据的冗余度很大,浪费了存储空间。,关系模式规范化的提出,2. 插入异常。如果某个新系没有招生,尚无学生时,则系名和系主任的信息无法插入到数据

4、库中。 (1)因为在这个关系模式中,(SNO,CNO)是主关系键。根据关系的实体完整性约束,主关系键的值不能为空,而这时没有学生,SNO和CNO均无值,因此不能进行插入操作。 (2)另外,当某个学生尚未选课,即CNO未知,实体完整性约束还规定,主关系键的值不能部分为空,同样不能进行插入操作。,关系模式规范化的提出,3. 删除异常。 某系学生全部毕业而没有招生时,删除全部学生的记录则系名、系主任也随之删除,而这个系依然存在,在数据库中却无法找到该系的信息。 另外,如果某个学生不再选修C1课程,本应该只删去C1,但C1是主关系键的一部分,为保证实体完整性,必须将整个元组一起删掉,这样,有关该学生的

5、其它信息也随之丢失。,关系模式规范化的提出,4. 更新异常。 如果学生改名,则该学生的所有记录都要逐一修改SN; 又如某系更换系主任,则属于该系的学生记录都要修改MN的内容,稍有不慎,就有可能漏改某些记录,这就会造成数据的不一致性,破坏了数据的完整性。,关系模式规范化的提出,由于存在以上问题,我们说,SCD是一个不好的关系模式。产生上述问题的原因,直观地说,是因为关系中“包罗万象”,内容太杂了。那么,怎样才能得到一个好的关系模式呢? 我们把关系模式SCD分解为下面三个结构简单的关系模式,如图所示。 学生关系S(SNO,SN,AGE,DEPT) 选课关系SC(SNO,CNO,SCORE) 系关系

6、D(DEPT,MN),关系模式规范化的提出,SC,S,关系模式规范化的提出,在以上三个关系模式中,实现了信息的某种程度的分离, S中存储学生基本信息,与所选课程及系主任无关; D中存储系的有关信息,与学生无关; SC中存储学生选课的信息,而与所学生及系的有关信息无关。,关系模式规范化的提出,与SCD相比,分解为三个关系模式后,数据的冗余度明显降低。 1)当新插入一个系时,只要在关系D中添加一条记录。 2)当某个学生尚未选课,只要在关系S中添加一条学生记录,而与选课关系无关,这就避免了插入异常。 3)当一个系的学生全部毕业时,只需在S中删除该系的全部学生记录,而关系D中有关该系的信息仍然保留,从

7、而不会引起删除异常。 4)同时,由于数据冗余度的降低,数据没有重复存储,也不会引起更新异常。,关系模式规范化的提出,经过上述分析,我们说分解后的关系模式是一个好的关系数据库模式。 从而得出结论,一个好的关系模式应该具备以下四个条件: 尽可能少的数据冗余。 没有插入异常。 没有删除异常。 没有更新异常。,关系模式规范化的提出,但要注意,一个好的关系模式并不是在任何情况下都是最优的 比如查询某个学生选修课程名及所在系的系主任时,要通过连接,而连接所需要的系统开销非常大,因此要以实际设计的目标出发进行设计。,关系模式应满足的基本要求,元组的每个分量必须是不可分的数据项。 数据库中的数据冗余应尽可能少

8、。 关系数据库不能因为数据更新操作而引起数据不一致问题。 当执行数据插入操作时,数据库中的数据不能产生插入异常现象。 数据库中的数据不能在执行删除操作时产生删除异常问题。 数据库设计应考虑查询要求,数据组织应合理。,函数依赖及其关系的范式,关系模式的简化表示法 关系模式的完整表示是一个五元组: RU,D,Dom,F. 其中:R为关系名;U为关系的属性集合;D为属性集U中属性的数据域;Dom为属性到域的映射;F为属性集U的数据依赖集。 关系模式可以用三元组来为: RU,F,函数依赖及其关系的范式,关系模式中的各属性之间相互依赖、相互制约的联系称为数据依赖。 数据依赖一般分为函数依赖、多值依赖和连

9、接依赖。其中,函数依赖是最重要的数据依赖。 函数依赖(Functional Dependency)是关系模式中属性之间的一种逻辑依赖关系。,函数依赖及其关系的范式,所谓的函数依赖是指一个或一组属性的值可以决定其他属性的值。 例如在上一节介绍的关系模式SCD中,SNO与SN、AGE、DEPT之间都有一种依赖关系。 由于一个SNO只对应一个学生,而一个学生只能属于一个系,所以当SNO的值确定之后,SN,AGE,DEPT的值也随之被唯一的确定了。 这类似于变量之间的单值函数关系。设单值函数Y=F(X),自变量X的值可以决定一个唯一的函数值Y。在这里,我们说SNO决定函数(SN,AGE,DEPT),或

10、者说(SN,AGE,DEPT)函数依赖于SNO。,函数依赖及其关系的范式,根据以上得出的函数依赖的集合为 F= snoSN, snoage, sno dept,dept mn,(sno,cno) score),函数依赖及其关系的范式,定义 设关系模式R(U,F),U是属性全集,F是U上的函数依赖集,X和Y是U的子集,如果对于R(U)的任意一个可能的关系r,对于X的每一个具体值,Y都有唯一的具体值与之对应,则称X决定函数Y,或Y函数依赖于X,记作XY。我们称X为决定因素,Y为依赖因素。当Y不函数依赖于X时,记作:X Y。当XY且YX时,则记作X Y。,函数依赖及其关系的范式,对于关系模式SCD

11、U=SNO,SN,AGE,DEPT,MN,CNO,SCORE F=SNOSN,SNOAGE,SNODEPT 一个SNO有多个SCORE的值与其对应,因此SCORE不能唯一地确定,即SCORE不能函数依赖于SNO,所以有: SNO SCORE。 但是SCORE可以被(SNO,CNO)唯一地确定。所以可表示为:(SNO,CNO)SCORE。,函数依赖及其关系的范式,平凡的函数依赖与非平凡的函数依赖。 当属性集Y是属性集X的子集时,则必然存在着函数依赖XY,这种类型的函数依赖称为平凡的函数依赖。 如果Y不是X的子集,则称XY为非平凡的函数依赖。 若不特别声明,我们讨论的都是非平凡的函数依赖。,函数依

12、赖及其关系的范式,我们只能根据语义来确定一个函数依赖,而不能按照其形式化定义来证明一个函数依赖是否成立。 例如,对于关系模式S,当学生不存在重名的情况下,可以得到: SNAGESNDEPT 这种函数依赖关系,必须是在没有重名的学生条件下才成立的,否则就不存在函数依赖了。 所以函数依赖反映了一种语义完整性约束。,函数依赖及其关系的范式,函数依赖与属性之间的联系类型有关 (1)在一个关系模式中,如果属性X与Y有1:1联系时,则存在函数依赖XY,YX,即X Y。 例如,当学生无重名时,SNO SN。 (2)如果属性X与Y有1:m的联系时,则只存在函数依赖XY。 例如,SNO与AGE,DEPT之间均为

13、1:m联系,所以有SNOAGE,SNODEPT。 (3)如果属性X与Y有m: n的联系时,则X与Y之间不存在任何函数依赖关系。 例如,一个学生可以选修多门课程,一门课程又可以为多个学生选修,所以SNO与CNO之间不存在函数依赖关系。,函数依赖及其关系的范式,2) 在RU中,如果XY,并且对于X的任何一个真子集X,都有X Y,则称Y对X完全函数依赖,记作:XY;若XY,但Y不完全函数依赖于X,则称Y对X部分函数依赖,记作: XY。例如,在教学关系模式:(学号,课程名)成绩,(学号,课程名)姓名,F,P,F,P,函数依赖及其关系的范式,3) 在RU中,如果XY,(YX),Y X,YZ,则称Z对X传

14、递函数依赖。传递函数依赖记作X Z。传递例如,在教学模式中,因为:学号系名,系名系主任;所以:学号 系主任。,传递,传递,函数依赖及其关系的范式,如果关系模式R,其所有的属性均为简单属性,即每个属性都是不可再分的,则称R属于第一范式,记作R1NF。若R1NF,且每一个非主属性完全依赖于码,则R2NF。,函数依赖及其关系的范式,在教学模式中: 属性集=学号,姓名,年龄,系名,系主任,课程名,成绩. 函数依赖集=学号姓名,学号年龄,学号性别,学号系名,系名系主任,(学号,课程名)成绩. 主码=(学号,课程名). F非主属性=(姓名,年龄,系名,系主任,成绩)。,函数依赖及其关系的范式,非主属性对码

15、的函数依赖: (学号,课程名)姓名,(学号,课程名)年龄,(学号,课程号)性别 , (学号,课程名)系名,(学号,课程名)系主任;(学号,课程名)成绩.显然,教学模式不服从2NF,即:教学2NF。,P,P,P,P,P,函数依赖及其关系的范式,关系模式RU,F中若不存在这样的码X、属性组Y及非主属性Z(ZY)使得XY、Y X、YZ成立,则称RU,F3NF。可以证明,若R3NF,则每一个非主属性既不部分函数依赖于码,也不传递函数依赖于码。,函数依赖及其关系的范式,考查学生_系关系,由于存在:学号系名,系名系主任。 则: 学号 系主任。所以学生_系3NF。如果分解为: 学生(学号,姓名,年龄,性别,

16、系名); 教学系(系名,系主任).显然分解后的各子模式均属于3NF。,传递,函数依赖及其关系的范式,关系模式RU,F1NF。若XY且YX时X必含有码,则RU,FBCNF。也就是说,关系模式RU,F中,若每一个决定因素都包含码,则RU,FBCNF。由BCNF的定义可以得到结论,一个满足BCNF的关系模式有:1) 所有非主属性对每一个码都是完全函数依赖。2) 所有的主属性对每一个不包含它的码,也是完全依赖。3) 没有任何属性完全函数依赖于非码的任何一组属性。,函数依赖及其关系的范式,1) BCNF不仅强调其他属性对码的完全的直接的依赖,而且强调主属性对码的完全的直接的依赖,它包括3NF,即RBCNF,则R一定属于3NF。2) 3NF只强调非主属性对码的完

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论