数据库系统概论(第五版)ppt课件第6章

上传人:2127513****773577... 文档编号:240647451 上传时间:2024-04-27 格式:PPTX 页数:123 大小:939.57KB
收藏 版权申诉 举报 下载
数据库系统概论(第五版)ppt课件第6章_第1页
第1页 / 共123页
数据库系统概论(第五版)ppt课件第6章_第2页
第2页 / 共123页
数据库系统概论(第五版)ppt课件第6章_第3页
第3页 / 共123页
资源描述:

《数据库系统概论(第五版)ppt课件第6章》由会员分享,可在线阅读,更多相关《数据库系统概论(第五版)ppt课件第6章(123页珍藏版)》请在装配图网上搜索。

1、AnIntroductiontoDatabaseSystem数据库系统概论数据库系统概论AnIntroductiontoDatabaseSystem第六第六章章 关系数据理论关系数据理论xx大大学信息学院学信息学院数据库系统概论xx大学信息学院AnIntroductiontoDatabaseSystemv基于某个数据库管理系统设计数据库,如何基于基于某个数据库管理系统设计数据库,如何基于数据库系统编程数据库系统编程n第第6章章关系数据理论关系数据理论n第第7章章数据库设计数据库设计n第第8章章数据库编程数据库编程第二篇第二篇 设计与应用开发篇设计与应用开发篇基于某个数据库管理系统设计数据库,如

2、何基于数据库系统编程第二AnIntroductiontoDatabaseSystem第六章第六章关系数据理论关系数据理论6.1问题的提出问题的提出6.2规范化规范化6.3数据依赖的公理系统数据依赖的公理系统*6.4模式的分解模式的分解6.5小结小结第六章关系数据理论6.1问题的提出AnIntroductiontoDatabaseSystemAnIntroductiontoDatabaseSystem6.1问题的提出问题的提出关系数据库逻辑设计关系数据库逻辑设计n针对具体问题,如何构造一个适合于它的数据模式针对具体问题,如何构造一个适合于它的数据模式n数据库逻辑设计的工具数据库逻辑设计的工具关系

3、数据库的规范化理论关系数据库的规范化理论AnIntroductiontoDatabaseSyAnIntroductiontoDatabaseSystem*问题的提出(续)问题的提出(续)v关系模式由五部分组成,是一个五元组:关系模式由五部分组成,是一个五元组:R(U,D,DOM,F)n关系名关系名R是符号化的元组语义是符号化的元组语义nU为一组属性为一组属性nD为属性组为属性组U中的属性所来自的域中的属性所来自的域nDOM为属性到域的映射为属性到域的映射nF为属性组为属性组U上的一组数据依赖上的一组数据依赖*问题的提出(续)关系模式由五部分组成,是一个五元组:AnIntroductiontoD

4、atabaseSystem问题的提出(续)问题的提出(续)n由于由于D、DOM与模式设计关系不大,因此在本章中把与模式设计关系不大,因此在本章中把关系模式看作一个三元组:关系模式看作一个三元组:Rn当且仅当当且仅当U上的一个关系上的一个关系r满足满足F时,时,r称为关系模式称为关系模式R的一个关系的一个关系n作为二维表,关系要符合一个最基本的条件:每个分作为二维表,关系要符合一个最基本的条件:每个分量必须是不可分开的数据项。满足了这个条件的关系量必须是不可分开的数据项。满足了这个条件的关系模式就属于第一范式(模式就属于第一范式(1NF)问题的提出(续)由于D、DOM与模式设计关系不大,因此在本

5、章AnIntroductiontoDatabaseSystem*问题的提出(续)问题的提出(续)v数据依赖数据依赖n是一个关系内部属性与属性之间的一种约束关系是一个关系内部属性与属性之间的一种约束关系l通过属性间值的相等与否体现出来的数据间相互联系通过属性间值的相等与否体现出来的数据间相互联系n是现实世界属性间相互联系的抽象是现实世界属性间相互联系的抽象n是数据内在的性质是数据内在的性质n是语义的体现是语义的体现*问题的提出(续)数据依赖AnIntroductiontoDatabaseSystem*问题的提出(续)问题的提出(续)v数据依赖的主要类型数据依赖的主要类型n函数依赖(函数依赖(Fu

6、nctionalDependency,简记为,简记为FD)n多值依赖(多值依赖(Multi-ValuedDependency,简记为,简记为MVD)*问题的提出(续)数据依赖的主要类型AnIntroductiontoDatabaseSystem*问题的提出(续)问题的提出(续)v函数依赖普遍存在于现实生活中函数依赖普遍存在于现实生活中n描述一个学生关系,可以有学号、姓名、系名等属性。描述一个学生关系,可以有学号、姓名、系名等属性。l一个学号只对应一个学生,一个学生只在一个系中学习一个学号只对应一个学生,一个学生只在一个系中学习l“学号学号”值确定后,学生的姓名及所在系的值就被唯一确值确定后,学

7、生的姓名及所在系的值就被唯一确定。定。nSname=f(Sno),Sdept=f(Sno)l即即Sno函数决定函数决定SnamelSno函数决定函数决定Sdeptl记作记作SnoSname,SnoSdept*问题的提出(续)函数依赖普遍存在于现实生活中AnIntroductiontoDatabaseSystem*问题的提出(续)问题的提出(续)v例例6.1建立一个描述学校教务的数据库。建立一个描述学校教务的数据库。涉及的对象包括:涉及的对象包括:n学生的学号(学生的学号(Sno)n所在系(所在系(Sdept)n系主任姓名(系主任姓名(Mname)n课程号(课程号(Cno)n成绩(成绩(Grad

8、e)*问题的提出(续)例6.1建立一个描述学校教务的数据AnIntroductiontoDatabaseSystem*问题的提出(续)问题的提出(续)n假设学校教务的数据库模式用一个单一的关系模式假设学校教务的数据库模式用一个单一的关系模式Student来表示,则该关系模式的属性集合为:来表示,则该关系模式的属性集合为:USno,Sdept,Mname,Cno,Graden现实世界的已知事实(语义):现实世界的已知事实(语义):l一个系有若干学生,一个系有若干学生,但一个学生只属于一个系;但一个学生只属于一个系;l一个系只有一名(正职)负责人;一个系只有一名(正职)负责人;l一个学生可以选修多

9、门课程,每门课程有若干学生选修;一个学生可以选修多门课程,每门课程有若干学生选修;l每个学生学习每一门课程有一个成绩。每个学生学习每一门课程有一个成绩。*问题的提出(续)假设学校教务的数据库模式用一个单一的关系模AnIntroductiontoDatabaseSystem*问题的提出(续)问题的提出(续)n由此可得到属性组由此可得到属性组U上的一组函数依赖上的一组函数依赖F:F=SnoSdept,SdeptMname,(Sno,Cno)GradeSnoCnoSdeptMnameGrade*问题的提出(续)由此可得到属性组U上的一组函数依赖F:SAnIntroductiontoDatabaseS

10、ystem*问题的提出(续)问题的提出(续)关系模式关系模式Student中存在的问题:中存在的问题:(1)数据冗余)数据冗余n浪费大量的存储空间浪费大量的存储空间l每一个系主任的姓名重复出现,重复次数与该系所有学每一个系主任的姓名重复出现,重复次数与该系所有学生的所有课程成绩出现次数相同。生的所有课程成绩出现次数相同。*问题的提出(续)关系模式Student中存在的AnIntroductiontoDatabaseSystem*问题的提出(续)问题的提出(续)(2)更新异常()更新异常(UpdateAnomalies)n数据冗余数据冗余,更新数据时,维护数据完整性代价大。更新数据时,维护数据完

11、整性代价大。l某系更换系主任后,必须修改与该系学生有关的每一个某系更换系主任后,必须修改与该系学生有关的每一个元组。元组。*问题的提出(续)(2)更新异常(UpdateAnomalAnIntroductiontoDatabaseSystem*问题的提出(续)问题的提出(续)(3)插入异常()插入异常(InsertionAnomalies)n如果一个系刚成立,尚无学生,则无法把这个系及其如果一个系刚成立,尚无学生,则无法把这个系及其系主任的信息存入数据库。系主任的信息存入数据库。*问题的提出(续)(3)插入异常(InsertionAnoAnIntroductiontoDatabaseSystem

12、*问题的提出(续)问题的提出(续)(4)删除异常()删除异常(DeletionAnomalies)n如果某个系的学生全部毕业了,如果某个系的学生全部毕业了,则在删除该系学生信则在删除该系学生信息的同时,把这个系及其系主任的信息也丢掉了。息的同时,把这个系及其系主任的信息也丢掉了。*问题的提出(续)(4)删除异常(DeletionAnomAnIntroductiontoDatabaseSystem*问题的提出(续)问题的提出(续)v结论结论nStudent关系模式不是一个好的模式。关系模式不是一个好的模式。n一个一个“好好”的模式应当不会发生插入异常、删除异常和更的模式应当不会发生插入异常、删除

13、异常和更新异常,数据冗余应尽可能少。新异常,数据冗余应尽可能少。v原因原因n由存在于模式中的某些数据依赖引起的。由存在于模式中的某些数据依赖引起的。v解决方法解决方法n用规范化理论改造关系模式来消除其中不合适的数据依赖用规范化理论改造关系模式来消除其中不合适的数据依赖*问题的提出(续)结论AnIntroductiontoDatabaseSystem*问题的提出(续)问题的提出(续)v把这个单一的模式分成三个关系模式:把这个单一的模式分成三个关系模式:nS(Sno,Sdept,SnoSdept);nSC(Sno,Cno,Grade,(Sno,Cno)Grade);nDEPT(Sdept,Mnam

14、e,SdeptMname);v这三个模式都不会发生插入异常、删除异常的问这三个模式都不会发生插入异常、删除异常的问题,数据的冗余也得到了控制。题,数据的冗余也得到了控制。*问题的提出(续)把这个单一的模式分成三个关系模式:AnIntroductiontoDatabaseSystem第六章第六章关系数据理论关系数据理论6.1问题的提出问题的提出6.2规范化规范化6.3数据依赖的公理系统数据依赖的公理系统*6.4模式的分解模式的分解6.5小结小结第六章关系数据理论6.1问题的提出AnIntroductiontoDatabaseSystem6.2规范化规范化6.2.1函数依赖函数依赖6.2.2码码6

15、.2.3范式范式6.2.42NF6.2.53NF6.2.6BCNF6.2.7多值依赖多值依赖6.2.84NF6.2.9规范化小结规范化小结6.2规范化6.2.1函数依赖AnIntroductiontoDatabaseSystem6.2.1函数依赖函数依赖1.函数依赖函数依赖2.平凡函数依赖与非平凡函数依赖平凡函数依赖与非平凡函数依赖3.完全函数依赖与部分函数依赖完全函数依赖与部分函数依赖4.传递函数依赖传递函数依赖6.2.1函数依赖1.函数依赖AnIntroductiontoDatabaseSystem*1.函数依赖函数依赖v定义定义6.1设设R(U)是一个属性集是一个属性集U上的关系模式,上

16、的关系模式,X和和Y是是U的子集。若对于的子集。若对于R(U)的任意一个可能的关的任意一个可能的关系系r,r中不可能存在两个元组在中不可能存在两个元组在X上的属性值相上的属性值相等,等,而在而在Y上的属性值不等,上的属性值不等,则称则称“X函数确定函数确定Y”或或“Y函数依赖于函数依赖于X”,记作,记作XY。*1.函数依赖定义6.1设R(U)是一个属性集U上的AnIntroductiontoDatabaseSystem函数依赖(续)函数依赖(续)v例例Student(Sno,Sname,Ssex,Sage,Sdept),假设不允许重名,则有假设不允许重名,则有:SnoSsex,SnoSageS

17、noSdept,SnoSnameSnameSsex,SnameSageSnameSdept但但SsexSage,SsexSdept若若XY,并且,并且YX,则记为则记为XY。若若Y不函数依赖于不函数依赖于X,则记为则记为XY。函数依赖(续)例Student(Sno,Sname,AnIntroductiontoDatabaseSystem函数依赖(续)函数依赖(续)SnoSnameSsexSageSdeptS1 张三张三男男20计算机系计算机系S1李四李四女女21自动化系自动化系S3王五王五男男20计算机系计算机系S4赵六赵六男男21计算机系计算机系S5田七田七男男20计算机系计算机系.违背了违

18、背了SnoSname函数依赖(续)SnoSnameSsexSageSdeptS1AnIntroductiontoDatabaseSystem函数依赖(续)函数依赖(续)v由下面的关系表由下面的关系表,能否得出能否得出SnoSnameSnoSnameSsexSageSdeptS1张三张三男男20计算机系计算机系S2李四李四女女21自动化系自动化系S3王五王五男男20计算机系计算机系S4赵六赵六男男21计算机系计算机系S5田七田七男男20计算机系计算机系.函数依赖不是指关系模式函数依赖不是指关系模式R的某个或某些关系实例满足的的某个或某些关系实例满足的约束条件,而是指约束条件,而是指R的所有关系实

19、例均要满足的约束条件。的所有关系实例均要满足的约束条件。函数依赖(续)由下面的关系表,能否得出SnoSnamAnIntroductiontoDatabaseSystem*函数依赖(续)函数依赖(续)v函数依赖是语义范畴的概念,只能根据数据的语函数依赖是语义范畴的概念,只能根据数据的语义来确定一个函数依赖。义来确定一个函数依赖。n例如例如“姓名姓名年龄年龄”这个函数依赖只有在不允许有同这个函数依赖只有在不允许有同名人的条件下成立名人的条件下成立*函数依赖(续)函数依赖是语义范畴的概念,只能根据数据的语义AnIntroductiontoDatabaseSystem*2.平凡函数依赖与非平凡函数依赖

20、平凡函数依赖与非平凡函数依赖vXY,但,但Y X则称则称XY是是非平凡的函数依赖非平凡的函数依赖。vXY,但,但Y X则称则称XY是是平凡的函数依赖平凡的函数依赖。对于任一关系模式,平凡函数依赖都是必然成立的,它对于任一关系模式,平凡函数依赖都是必然成立的,它不反映新的语义。不反映新的语义。若不特别声明,若不特别声明,我们总是讨论非平凡函数依赖。我们总是讨论非平凡函数依赖。*2.平凡函数依赖与非平凡函数依赖XY,但YX则称XAnIntroductiontoDatabaseSystem*平凡函数依赖与非平凡函数依赖(续)平凡函数依赖与非平凡函数依赖(续)v若若XY,则,则X称为这个函数依赖的称为

21、这个函数依赖的决定因素决定因素(Determinant)。)。v若若XY,YX,则记作,则记作XY。v若若Y不函数依赖于不函数依赖于X,则记作,则记作XY。*平凡函数依赖与非平凡函数依赖(续)若XY,则X称为这个函AnIntroductiontoDatabaseSystem*3.完全函数依赖与部分函数依赖完全函数依赖与部分函数依赖v定义定义6.2在在R(U)中,如果中,如果XY,并且对于,并且对于X的任的任何一个真子集何一个真子集X,都有都有X Y,则称则称Y对对X完全函数完全函数依赖依赖,记作,记作XY。v若若XY,但,但Y不完全函数依赖于不完全函数依赖于X,则称,则称Y对对X部部分函数依赖

22、分函数依赖,记作,记作XYFP*3.完全函数依赖与部分函数依赖定义6.2在R(U)中AnIntroductiontoDatabaseSystem*完全函数依赖与部分函数依赖(续)完全函数依赖与部分函数依赖(续)v例例在关系在关系SC(Sno,Cno,Grade)中,有:中,有:n由于:由于:SnoGrade,CnoGrade,因此:因此:(Sno,Cno)Grade(Sno,Cno)Sno(Sno,Cno)CnoFPP*完全函数依赖与部分函数依赖(续)例在关系SC(SnoAnIntroductiontoDatabaseSystem*4.传递函数依赖传递函数依赖v定义定义6.3在在R(U)中,如

23、果中,如果XY(Y X),YX,YZ,Z Y,则称则称Z对对X传递函数依赖传递函数依赖(transitivefunctionaldependency)。记为:。记为:XZ。n注注:如果如果YX,即即XY,则,则Z直接依赖于直接依赖于X,而不是,而不是传递函数依赖。传递函数依赖。n例例在关系在关系Std(Sno,Sdept,Mname)中,有:中,有:SnoSdept,SdeptMname,Mname传递函数依赖于传递函数依赖于Sno传递传递*4.传递函数依赖定义6.3在R(U)中,如果XY(AnIntroductiontoDatabaseSystem6.2规范化规范化6.2.1函数依赖函数依赖

24、6.2.2码码6.2.3范式范式6.2.42NF6.2.53NF6.2.6BCNF6.2.7多值依赖多值依赖6.2.84NF6.2.9规范化小结规范化小结6.2规范化6.2.1函数依赖AnIntroductiontoDatabaseSystem*6.2.2码码v定义定义6.4设设K为为R中的属性或属性组合。若中的属性或属性组合。若KU,则,则K称为称为R的一个的一个候选码候选码(CandidateKey)。n如果如果U部分函数依赖于部分函数依赖于K,即,即KU,则则K称为超码称为超码(Surpkey)。候选码是最小的超码,即)。候选码是最小的超码,即K的任意一个的任意一个真子集都不是候选码。真

25、子集都不是候选码。v若关系模式若关系模式R有多个候选码,则选定其中的一个有多个候选码,则选定其中的一个做为做为主码主码(Primarykey)。FP*6.2.2码定义6.4设K为R中的属性或AnIntroductiontoDatabaseSystem*码(续)码(续)v主属性与非主属性主属性与非主属性n包含在任何一个候选码中的属性包含在任何一个候选码中的属性,称为主属性,称为主属性(Primeattribute)n不包含在任何码中的属性称为非主属性(不包含在任何码中的属性称为非主属性(Nonprimeattribute)或非码属性()或非码属性(Non-keyattribute)v全码:整个属

26、性组是码,称为全码(全码:整个属性组是码,称为全码(All-key)*码(续)主属性与非主属性AnIntroductiontoDatabaseSystem*码(续)码(续)例例6.2S(Sno,Sdept,Sage),单个属性,单个属性Sno是码是码SC(Sno,Cno,Grade)中,中,(Sno,Cno)是码是码例例6.3R(P,W,A)P:演奏者:演奏者W:作品:作品A:听众:听众一个演奏者可以演奏多个作品一个演奏者可以演奏多个作品某一作品可被多个演奏者演奏某一作品可被多个演奏者演奏听众可以欣赏不同演奏者的不同作品听众可以欣赏不同演奏者的不同作品 码为码为(P,W,A),即,即All-K

27、ey*码(续)例6.2S(Sno,Sdept,Sage)AnIntroductiontoDatabaseSystem*码(续)码(续)v定义定义6.5关系模式关系模式R中属性或属性组中属性或属性组X并非并非R的的码,但码,但X是另一个关系模式的码,则称是另一个关系模式的码,则称X是是R的的外部码外部码(Foreignkey)也称)也称外码外码。nSC(Sno,Cno,Grade)中,中,Sno不是码不是码nSno是是S(Sno,Sdept,Sage)的码,则的码,则Sno是是SC的外码的外码v主码与外部码一起提供了表示关系间联系的手段主码与外部码一起提供了表示关系间联系的手段*码(续)定义6.

28、5关系模式R中属性或属性组X并非AnIntroductiontoDatabaseSystem6.2规范化规范化6.2.1函数依赖函数依赖6.2.2码码6.2.3范式范式6.2.42NF6.2.53NF6.2.6BCNF6.2.7多值依赖多值依赖6.2.84NF6.2.9规范化小结规范化小结6.2规范化6.2.1函数依赖AnIntroductiontoDatabaseSystem*6.2.3范式范式v范式是符合某一种级别的关系模式的集合。范式是符合某一种级别的关系模式的集合。v关系数据库中的关系必须满足一定的要求。满足关系数据库中的关系必须满足一定的要求。满足不同程度要求的为不同范式。不同程度要

29、求的为不同范式。v范式的种类:范式的种类:第一范式第一范式(1NF)第二范式第二范式(2NF)第三范式第三范式(3NF)BC范式范式(BCNF)第四范式第四范式(4NF)第五范式第五范式(5NF)*6.2.3范式范式是符合某一种级别的关系模式的集合。第AnIntroductiontoDatabaseSystem*范式(续)范式(续)v各种范式之间存在联系:各种范式之间存在联系:n某一关系模式某一关系模式R为第为第n范式,可简记为范式,可简记为R nNF。v一个低一级范式的关系模式,通一个低一级范式的关系模式,通过模式分解(过模式分解(schemadecomposition)可以转换为若)可以转

30、换为若干个高一级范式的关系模式的集干个高一级范式的关系模式的集合,这种过程就叫合,这种过程就叫规范化规范化(normalization)。)。*范式(续)各种范式之间存在联系:一个低一级范式的关系模式,AnIntroductiontoDatabaseSystem6.2规范化规范化6.2.1函数依赖函数依赖6.2.2码码6.2.3范式范式6.2.42NF6.2.53NF6.2.6BCNF6.2.7多值依赖多值依赖6.2.84NF6.2.9规范化小结规范化小结6.2规范化6.2.1函数依赖AnIntroductiontoDatabaseSystem*6.2.42NFv定义定义6.6若关系模式若关系

31、模式R 1NF,并且每一个非主属性,并且每一个非主属性都完全函数依赖于任何一个候选码,则都完全函数依赖于任何一个候选码,则R 2NFv例例6.4S-L-C(Sno,Sdept,Sloc,Cno,Grade),Sloc为学生的住处,并且每个系的学生住在同一个为学生的住处,并且每个系的学生住在同一个地方。地方。S-L-C的码为的码为(Sno,Cno)。函数依赖有函数依赖有n(Sno,Cno)GradenSnoSdept,(Sno,Cno)SdeptnSnoSloc,(Sno,Cno)SlocnSdeptSlocFPP*6.2.42NF定义6.6若关系模式R1NF,并AnIntroductionto

32、DatabaseSystem*2NF(续)(续)SnoCnoGradeSdeptSlocn关系模式关系模式S-L-C不属于不属于2NFn非主属性非主属性Sdept、Sloc并不完全依赖于码并不完全依赖于码*2NF(续)SnoCnoGradeSdeptSloc关系模AnIntroductiontoDatabaseSystem*2NF(续)(续)v一个关系模式不属于一个关系模式不属于2NF,会产生以下问题:,会产生以下问题:n插入异常插入异常l如果插入一个新学生,但该生未选课,即该生无如果插入一个新学生,但该生未选课,即该生无Cno,由于插入元组时,必须给定码值,因此插入失败。由于插入元组时,必须

33、给定码值,因此插入失败。n删除异常删除异常l如果如果S4只选了一门课只选了一门课C3,现在他不再选这门课,则删除,现在他不再选这门课,则删除C3后,整个元组的其他信息也被删除了。后,整个元组的其他信息也被删除了。n修改复杂修改复杂l如果一个学生选了多门课,则如果一个学生选了多门课,则Sdept,Sloc被存储了多被存储了多次。如果该生转系,则需要修改所有相关的次。如果该生转系,则需要修改所有相关的Sdept和和Sloc,造成修改的复杂化。,造成修改的复杂化。*2NF(续)一个关系模式不属于2NF,会产生以下问题:AnIntroductiontoDatabaseSystem*2NF(续)(续)v

34、出现这种问题的原因出现这种问题的原因n例子中有两类非主属性:例子中有两类非主属性:l一类如一类如Grade,它对码完全函数依赖,它对码完全函数依赖l另一类如另一类如Sdept、Sloc,它们对码不是完全函数依赖,它们对码不是完全函数依赖v解决方法:解决方法:n用投影分解把关系模式用投影分解把关系模式S-L-C分解成两个关系模式分解成两个关系模式lSC(Sno,Cno,Grade)lS-L(Sno,Sdept,Sloc)*2NF(续)出现这种问题的原因AnIntroductiontoDatabaseSystem2NF(续)(续)nSC的码为的码为(Sno,Cno),SL的码为的码为Sno,这样使

35、得非主属,这样使得非主属性对码都是完全函数依赖了性对码都是完全函数依赖了SnoCnoGradeSnoSdeptSloc图图6.4SC中的函数依赖中的函数依赖图图6.5S-L中的函数依赖中的函数依赖2NF(续)SC的码为(Sno,Cno),SL的码为Sno,AnIntroductiontoDatabaseSystem6.2规范化规范化6.2.1函数依赖函数依赖6.2.2码码6.2.3范式范式6.2.42NF6.2.53NF6.2.6BCNF6.2.7多值依赖多值依赖6.2.84NF6.2.9规范化小结规范化小结6.2规范化6.2.1函数依赖AnIntroductiontoDatabaseSyst

36、em*6.2.53NFv定义定义6.7设关系模式设关系模式R 1NF,若若R中不存在中不存在这样的码这样的码X、属性组、属性组Y及非主属性及非主属性Z(Z Y),使使得得XY,YZ成立,成立,YX不成立,则称不成立,则称R 3NF。nSC没有传递依赖,因此没有传递依赖,因此SC 3NFnS-L中中SnoSdept(SdeptSno),SdeptSloc,可得可得SnoSloc。n解决的办法是将解决的办法是将S-L分解成分解成lS-D(Sno,Sdept)3NFlD-L(Sdept,Sloc)3NF传递传递*6.2.53NF定义6.7设关系模式RAnIntroductiontoDatabaseS

37、ystem6.2规范化规范化6.2.1函数依赖函数依赖6.2.2码码6.2.3范式范式6.2.42NF6.2.53NF6.2.6BCNF6.2.7多值依赖多值依赖6.2.84NF6.2.9规范化小结规范化小结6.2规范化6.2.1函数依赖AnIntroductiontoDatabaseSystem*6.2.6BCNFvBCNF(BoyceCoddNormalForm)由)由Boyce和和Codd提出,比提出,比3NF更进了一步。通常认为更进了一步。通常认为BCNF是修正的第三范式,有时也称为扩充的第是修正的第三范式,有时也称为扩充的第三范式。三范式。v定义定义6.8设关系模式设关系模式R 1N

38、F,若,若XY且且YX时时X必含有码,则必含有码,则R BCNF。v换言之,在关系模式换言之,在关系模式R中,如果每一个决定中,如果每一个决定属性集都包含候选码,则属性集都包含候选码,则R BCNF。*6.2.6BCNFBCNF(BoyceCoddNAnIntroductiontoDatabaseSystem*BCNF(续)(续)vBCNF的关系模式所具有的性质的关系模式所具有的性质n所有非主属性都完全函数依赖于每个候选码所有非主属性都完全函数依赖于每个候选码n所有主属性都完全函数依赖于每个不包含它的候选码所有主属性都完全函数依赖于每个不包含它的候选码n没有任何属性完全函数依赖于非码的任何一组

39、属性没有任何属性完全函数依赖于非码的任何一组属性v如如果果一一个个关关系系数数据据库库中中的的所所有有关关系系模模式式都都属属于于BCNF,那那么么在在函函数数依依赖赖范范畴畴内内,它它已已实实现现了了模模式式的的彻彻底底分分解解,达达到到了了最最高高的的规规范范化化程程度度,消消除除了了插插入异常和删除异常。入异常和删除异常。*BCNF(续)BCNF的关系模式所具有的性质AnIntroductiontoDatabaseSystemv例例6.5考察关系模式考察关系模式C(Cno,Cname,Pcno)n它它只只有有一一个个码码Cno,没没有有任任何何属属性性对对Cno部部分分依依赖赖或或传递依

40、赖,所以传递依赖,所以C 3NF。n同时同时C中中Cno是唯一的决定因素,所以是唯一的决定因素,所以C BCNF。n对于关系模式对于关系模式SC(Sno,Cno,Grade)可作同样分析。可作同样分析。BCNF(续)(续)例6.5考察关系模式C(Cno,Cname,Pcno)BAnIntroductiontoDatabaseSystemv例例6.6关系模式关系模式S(Sno,Sname,Sdept,Sage),n假定假定Sname也具有唯一性,那么也具有唯一性,那么S就有两个码,这两个就有两个码,这两个码都由单个属性组成,彼此不相交。码都由单个属性组成,彼此不相交。n其他属性不存在对码的传递依

41、赖与部分依赖,所以其他属性不存在对码的传递依赖与部分依赖,所以S 3NF。n同时同时S中除中除Sno,Sname外没有其他决定因素,所以外没有其他决定因素,所以S也属于也属于BCNF。BCNF(续)续)例6.6关系模式S(Sno,Sname,Sdept,SAnIntroductiontoDatabaseSystemv例例6.7关系模式关系模式SJP(S,J,P)中,中,S是学生,是学生,J表示表示课程,课程,P表示名次。每一个学生选修每门课程的表示名次。每一个学生选修每门课程的成绩有一定的名次,每门课程中每一名次只有一成绩有一定的名次,每门课程中每一名次只有一个学生(即没有并列名次)。个学生(

42、即没有并列名次)。n由语义可得到函数依赖:由语义可得到函数依赖:(S,J)P;(J,P)Sn(S,J)与与(J,P)都可以作为候选码。都可以作为候选码。n关系模式中没有属性对码传递依赖或部分依赖,所以关系模式中没有属性对码传递依赖或部分依赖,所以SJP 3NF。n除除(S,J)与与(J,P)以外没有其他决定因素,所以以外没有其他决定因素,所以SJP BCNF。BCNF(续)(续)例6.7关系模式SJP(S,J,P)中,S是学生,J表AnIntroductiontoDatabaseSystemBCNF(续)(续)v例例6.8关系模式关系模式STJ(S,T,J)中,中,S表示学生,表示学生,T表表

43、示教师,示教师,J表示课程。每一教师只教一门课。每表示课程。每一教师只教一门课。每门课有若干教师,某一学生选定某门课,就对应门课有若干教师,某一学生选定某门课,就对应一个固定的教师。一个固定的教师。n由语义可得到函数依赖:由语义可得到函数依赖:(S,J)T;(S,T)J;TJn因为没有任何非主属性对码传递依赖或部分依赖,因为没有任何非主属性对码传递依赖或部分依赖,STJ 3NF。n因为因为T是决定因素,而是决定因素,而T不包含码,所以不包含码,所以STJ BCNF关系。关系。图图6.6STJ中的函数依赖中的函数依赖BCNF(续)例6.8关系模式STJ(S,T,J)中,AnIntroductio

44、ntoDatabaseSystemBCNF(续)(续)v对于不是对于不是BCNF的关系模式,仍然存在不合适的的关系模式,仍然存在不合适的地方。地方。v非非BCNF的关系模式也可以通过分解成为的关系模式也可以通过分解成为BCNF。例如例如STJ可分解为可分解为ST(S,T)与与TJ(T,J),它们都是,它们都是BCNF。BCNF(续)对于不是BCNF的关系模式,仍然存在不合适的地AnIntroductiontoDatabaseSystemBCNF(续)(续)v3NF和和BCNF是在函数依赖的条件下对模式分解所是在函数依赖的条件下对模式分解所能达到的分离程度的测度。能达到的分离程度的测度。n一个模

45、式中的关系模式如果都属于一个模式中的关系模式如果都属于BCNF,那么在函数,那么在函数依赖范畴内,它已实现了彻底的分离,已消除了插入依赖范畴内,它已实现了彻底的分离,已消除了插入和删除的异常。和删除的异常。n3NF的的“不彻底不彻底”性表现在可能存在主属性对码的部分性表现在可能存在主属性对码的部分依赖和传递依赖。依赖和传递依赖。BCNF(续)3NF和BCNF是在函数依赖的条件下对模式分解AnIntroductiontoDatabaseSystem6.2规范化规范化6.2.1函数依赖函数依赖6.2.2码码6.2.3范式范式6.2.42NF6.2.53NF6.2.6BCNF6.2.7多值依赖多值依

46、赖6.2.84NF6.2.9规范化小结规范化小结6.2规范化6.2.1函数依赖AnIntroductiontoDatabaseSystem*6.2.7多值依赖多值依赖例例6.9设学校中某一门课程由多个教师讲授,他们设学校中某一门课程由多个教师讲授,他们使用相同的一套参考书。使用相同的一套参考书。每个教员可以讲授多门课每个教员可以讲授多门课程,每种参考书可以供多门课程使用程,每种参考书可以供多门课程使用用关系模式用关系模式Teaching(C,T,B)来表示课程来表示课程C、教师、教师T和参和参考书考书B之间的关系。之间的关系。*6.2.7多值依赖例6.9设学校中某一门课程由多个教AnIntro

47、ductiontoDatabaseSystem多值依赖(续)多值依赖(续)表表6.3非规范化关系示例非规范化关系示例课程课程 C教员教员 T参考书参考书 B物理物理数学数学计算数学计算数学李李勇勇王王军军李李勇勇张张平平张张平平周周峰峰普通物理学普通物理学光学原理光学原理物理习题集物理习题集数学分析数学分析微分方程微分方程高等代数高等代数数学分析数学分析多值依赖(续)表6.3非规范化关系示例课程C教员AnIntroductiontoDatabaseSystem*多值依赖(续)多值依赖(续)表表6.4规范化规范化的二维表的二维表Teaching课程课程C教员教员T参考书参考书B物物理理李李勇勇普

48、通物理学普通物理学物物理理李李勇勇光学原理光学原理物物理理李李勇勇物理习题集物理习题集物物理理王王军军普通物理学普通物理学物物理理王王军军光学原理光学原理物物理理王王军军物理习题集物理习题集数数学学李李勇勇普通物理学普通物理学数数学学李李勇勇光学原理光学原理数数学学李李勇勇物理习题集物理习题集数数学学张张平平普通物理学普通物理学数数学学张张平平光学原理光学原理数数学学张张平平物理习题集物理习题集*多值依赖(续)表6.4规范化的二维表TeachingAnIntroductiontoDatabaseSystem*多值依赖(续)多值依赖(续)vTeaching具有唯一候选码具有唯一候选码(C,T,B

49、),即全码。即全码。vTeaching BCNF*多值依赖(续)Teaching具有唯一候选码(C,T,B)AnIntroductiontoDatabaseSystem*多值依赖(续)多值依赖(续)课程课程C教员教员T参考书参考书B物物理理李李勇勇普通物理学普通物理学物物理理李李勇勇光学原理光学原理物物理理李李勇勇物理习题集物理习题集物物理理王王军军普通物理学普通物理学物物理理王王军军光学原理光学原理物物理理王王军军物理习题集物理习题集数数学学李李勇勇普通物理学普通物理学数数学学李李勇勇光学原理光学原理数数学学李李勇勇物理习题集物理习题集数数学学张张平平普通物理学普通物理学数数学学张张平平光学

50、原理光学原理数数学学张张平平物理习题集物理习题集(1)数据冗余度大:有多数据冗余度大:有多少名任课教师,参考书少名任课教师,参考书就要存储多少次。就要存储多少次。*多值依赖(续)课程C教员T参考书B物理李勇普通物AnIntroductiontoDatabaseSystem*多值依赖(续)多值依赖(续)课程课程C教员教员T参考书参考书B物物理理李李勇勇普通物理学普通物理学物物理理李李勇勇光学原理光学原理物物理理李李勇勇物理习题集物理习题集物物理理王王军军普通物理学普通物理学物物理理王王军军光学原理光学原理物物理理王王军军物理习题集物理习题集数数学学李李勇勇普通物理学普通物理学数数学学李李勇勇光学

51、原理光学原理数数学学李李勇勇物理习题集物理习题集数数学学张张平平普通物理学普通物理学数数学学张张平平光学原理光学原理数数学学张张平平物理习题集物理习题集(2)增加操作复杂:当增加操作复杂:当某一课程增加一名任某一课程增加一名任课教师时,该课程有课教师时,该课程有多少本参照书,就必多少本参照书,就必须插入多少个元组。须插入多少个元组。*多值依赖(续)课程C教员T参考书B物理李勇普通物AnIntroductiontoDatabaseSystem*多值依赖(续)多值依赖(续)课程课程C教员教员T参考书参考书B物物理理李李勇勇普通物理学普通物理学物物理理李李勇勇光学原理光学原理物物理理李李勇勇物理习题

52、集物理习题集物物理理王王军军普通物理学普通物理学物物理理王王军军光学原理光学原理物物理理王王军军物理习题集物理习题集数数学学李李勇勇普通物理学普通物理学数数学学李李勇勇光学原理光学原理数数学学李李勇勇物理习题集物理习题集数数学学张张平平普通物理学普通物理学数数学学张张平平光学原理光学原理数数学学张张平平物理习题集物理习题集(3)删除操作复杂:某一删除操作复杂:某一门课要去掉一本参考书,门课要去掉一本参考书,该课程有多少名教师,该课程有多少名教师,就必须删除多少个元组。就必须删除多少个元组。*多值依赖(续)课程C教员T参考书B物理李勇普通物AnIntroductiontoDatabaseSyst

53、em*多值依赖(续)多值依赖(续)课程课程C教员教员T参考书参考书B物物理理李李勇勇普通物理学普通物理学物物理理李李勇勇光学原理光学原理物物理理李李勇勇物理习题集物理习题集物物理理王王军军普通物理学普通物理学物物理理王王军军光学原理光学原理物物理理王王军军物理习题集物理习题集数数学学李李勇勇普通物理学普通物理学数数学学李李勇勇光学原理光学原理数数学学李李勇勇物理习题集物理习题集数数学学张张平平普通物理学普通物理学数数学学张张平平光学原理光学原理数数学学张张平平物理习题集物理习题集(4)修改操作复杂:某一修改操作复杂:某一门课要修改一本参考书,门课要修改一本参考书,该课程有多少名教师,该课程有多

54、少名教师,就必须修改多少个元组。就必须修改多少个元组。产生产生原因原因:存在多值依赖存在多值依赖*多值依赖(续)课程C教员T参考书B物理李勇普通物AnIntroductiontoDatabaseSystem*多值依赖(续)多值依赖(续)v定义定义6.9设设R(U)是属性集是属性集U上的一个关系模式。上的一个关系模式。X,Y,Z是是U的子集,并且的子集,并且Z=U-X-Y。关系模式。关系模式R(U)中多值依赖中多值依赖XY成立,当且仅当对成立,当且仅当对R(U)的任一的任一关系关系r,给定的一对,给定的一对(x,z)值,有一组值,有一组Y的值,这组的值,这组值仅仅决定于值仅仅决定于x值而与值而与

55、z值无关。值无关。v例例Teaching(C,T,B)对于对于C的每一个值,的每一个值,T有一组值与之对应,而不论有一组值与之对应,而不论B取何值。因此取何值。因此T多值依赖于多值依赖于C,即,即CT。*多值依赖(续)定义6.9设R(U)是属性集U上的一AnIntroductiontoDatabaseSystem多值依赖(续)多值依赖(续)v多值依赖的另一个等价的定义多值依赖的另一个等价的定义在在R(U)的任一关系的任一关系r中,如果存在元组中,如果存在元组t,s使得使得tX=sX,那么就必然存在元组,那么就必然存在元组w,vr,(,(w,v可以与可以与s,t相相同)同),使得使得wX=vX=

56、tX,而,而wY=tY,wZ=sZ,vY=sY,vZ=tZ(即交换(即交换s,t元组的元组的Y值所得的两值所得的两个新元组必在个新元组必在r中则中则Y多值依赖于多值依赖于X,记为,记为XY。这里。这里X,Y是是U的子集,的子集,Z=U-X-Y。多值依赖(续)多值依赖的另一个等价的定义AnIntroductiontoDatabaseSystem*多值依赖(续)多值依赖(续)v平凡多值依赖和非平凡的多值依赖平凡多值依赖和非平凡的多值依赖n若若XY,而,而Z,即,即Z为空,为空,则称则称XY为为平凡平凡的多值依赖的多值依赖。n否则称否则称XY为为非平凡的多值依赖非平凡的多值依赖。*多值依赖(续)平凡

57、多值依赖和非平凡的多值依赖AnIntroductiontoDatabaseSystem多值依赖(续)多值依赖(续)WSCW1S1C1W1S1C2W1S1C3W1S2C1W1S2C2W1S2C3W2S3C4W2S3C5W2S4C4W2S4C5例例6.10关系模式关系模式WSC(W,S,C)中,中,W表示仓库,表示仓库,S表示保管表示保管员,员,C表示商品。假设每个仓库有若干个保管员,有若干种表示商品。假设每个仓库有若干个保管员,有若干种商品。每个保管员保管所在仓库的所有商品,每种商品被所商品。每个保管员保管所在仓库的所有商品,每种商品被所有保管员保管。有保管员保管。多值依赖(续)WSCW1S1C

58、1W1S1C2W1S1C3W1AnIntroductiontoDatabaseSystem多值依赖(续)多值依赖(续)v按照语义对于按照语义对于W的每一个值的每一个值Wi,S有一个完整的集有一个完整的集合与之对应而不问合与之对应而不问C取何值。所以取何值。所以WS。v如图如图6.7所示所示n对应对应W的某一个值的某一个值Wi的全部的全部S值记作值记作SWi(表示此仓库(表示此仓库工作的全部保管员)工作的全部保管员)n全部全部C值记作值记作CWi(表示在此仓库中存放的所有商品)(表示在此仓库中存放的所有商品)n应当有应当有SWi中的每一个值和中的每一个值和CWi中的每一个中的每一个C值对应值对应

59、n于是于是SWi与与CWi之间正好形成一个完全二分图,因而之间正好形成一个完全二分图,因而WS。多值依赖(续)按照语义对于W的每一个值Wi,S有一个完整的集AnIntroductiontoDatabaseSystem多值依赖(续)多值依赖(续)v由于由于C与与S的完全对称性,必然有的完全对称性,必然有WC成立。成立。图图6.7WS且且WC多值依赖(续)由于C与S的完全对称性,必然有WC成立。图AnIntroductiontoDatabaseSystem多值依赖(续)多值依赖(续)v多值依赖的性质多值依赖的性质(1)多值依赖具有对称性。)多值依赖具有对称性。即若即若XY,则,则XZ,其中,其中Z

60、UXYl多值依赖的对称性可以用完全二分图直观地表示出来。多值依赖的对称性可以用完全二分图直观地表示出来。l从从例例6.10容易看出,因为每个保管员保管所有商品,容易看出,因为每个保管员保管所有商品,同时每种商品被所有保管员保管,显然若同时每种商品被所有保管员保管,显然若WS,必然,必然有有WC。多值依赖(续)多值依赖的性质AnIntroductiontoDatabaseSystem*多值依赖(续)多值依赖(续)(2)多值依赖具有传递性。即若)多值依赖具有传递性。即若XY,YZ,则则XZ-Y。(3)函数依赖是多值依赖的特殊情况。即若)函数依赖是多值依赖的特殊情况。即若XY,则,则 XY。(4)若

61、)若XY,XZ,则,则XYZ。(5)若)若XY,XZ,则,则XYZ。(6)若)若XY,XZ,则,则XY-Z,XZ-Y。*多值依赖(续)(2)多值依赖具有传递性。即若XY,YAnIntroductiontoDatabaseSystem*多值依赖(续)多值依赖(续)v多值依赖与函数依赖的区别多值依赖与函数依赖的区别(1)多值依赖的有效性与属性集的范围有关)多值依赖的有效性与属性集的范围有关l若若XY在在U上成立,则在上成立,则在W(XY W U)上一定成)上一定成立;反之则不然,即立;反之则不然,即XY在在W(W U)上成立,在)上成立,在U上并不一定成立。上并不一定成立。l原因:多值依赖的定义中

62、不仅涉及属性组原因:多值依赖的定义中不仅涉及属性组X和和Y,而且涉,而且涉及及U中其余属性中其余属性Z。*多值依赖(续)多值依赖与函数依赖的区别AnIntroductiontoDatabaseSystem*多值依赖(续)多值依赖(续)n多值依赖的有效性与属性集的范围有关(续)多值依赖的有效性与属性集的范围有关(续)l一般地,在一般地,在R(U)上若有上若有XY在在W(W U)上成立,则上成立,则称称XY为为R(U)的嵌入型多值依赖。的嵌入型多值依赖。l函数依赖函数依赖XY的有效性仅决定于的有效性仅决定于X、Y这两个属性集的值这两个属性集的值l只要在只要在R(U)的任何一个关系的任何一个关系r中

63、,元组在中,元组在X和和Y上的值满上的值满足定义足定义6.l,则函数依赖,则函数依赖XY在任何属性集在任何属性集W(XY W U)上成立。上成立。*多值依赖(续)多值依赖的有效性与属性集的范围有关(续)AnIntroductiontoDatabaseSystem*多值依赖(续)多值依赖(续)(2)若函数依赖)若函数依赖XY在在R(U)上成立,则对于任何上成立,则对于任何Y Y均有均有XY 成立。多值依赖成立。多值依赖XY若在若在R(U)上成立,上成立,不能断言对于任何不能断言对于任何Y Y有有XY 成立。成立。*多值依赖(续)(2)若函数依赖XY在R(U)上成立,则AnIntroduction

64、toDatabaseSystem*多值依赖(续)多值依赖(续)例如,关系例如,关系R(A,B,C,D),ABC成立,当然也有成立,当然也有AD成立。有成立。有R的一个关系实例,在此实例上的一个关系实例,在此实例上AB是不成立的。是不成立的。ABCDa1b1c1d1a1b1c1d2a1b2c2d1a1b2c2d2表表6.6R的一个实例的一个实例*多值依赖(续)例如,关系R(A,B,C,D),AAnIntroductiontoDatabaseSystem6.2规范化规范化6.2.1函数依赖函数依赖6.2.2码码6.2.3范式范式6.2.42NF6.2.53NF6.2.6BCNF6.2.7多值依赖多

65、值依赖6.2.84NF6.2.9规范化小结规范化小结6.2规范化6.2.1函数依赖AnIntroductiontoDatabaseSystem*6.2.84NFv定义定义6.10关系模式关系模式R 1NF,如果对于,如果对于R的的每个非平凡多值依赖每个非平凡多值依赖XY(Y X),),X都含有都含有码,则码,则R 4NF。v4NF就是限制关系模式的属性之间不允许有非平就是限制关系模式的属性之间不允许有非平凡且非函数依赖的多值依赖。凡且非函数依赖的多值依赖。4NF所允许的非平所允许的非平凡多值依赖实际上是函数依赖。凡多值依赖实际上是函数依赖。*6.2.84NF定义6.10关系模式RAnIntro

66、ductiontoDatabaseSystem*4NF(续)(续)v如果一个关系模式是如果一个关系模式是4NF,则必为则必为BCNF。v在在例例6.10的的WSC中,中,WS,WC,他们都他们都是非平凡多值依赖。而是非平凡多值依赖。而W不是码,关系模式不是码,关系模式WSC的码是的码是(W,S,C),即,即All-key,因此,因此WSC4NF。v可以把可以把WSC分解成分解成WS(W,S),WC(W,C),WS4NF,WC4NF。*4NF(续)如果一个关系模式是4NF,则必为BCNF。AnIntroductiontoDatabaseSystem6.2规范化规范化6.2.1函数依赖函数依赖6.2.2码码6.2.3范式范式6.2.42NF6.2.53NF6.2.6BCNF6.2.7多值依赖多值依赖6.2.84NF6.2.9规范化小结规范化小结6.2规范化6.2.1函数依赖AnIntroductiontoDatabaseSystem*6.2.9规范化小结规范化小结v在关系数据库中,对关系模式的基本要求是满足在关系数据库中,对关系模式的基本要求是满足第一范式。第一范式。v规范化程度过低的关系

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

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


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