数据库原理配套课件Lesson-06.pptx

上传人(卖家):三亚风情 文档编号:2823297 上传时间:2022-05-29 格式:PPTX 页数:126 大小:448.79KB
下载 相关 举报
数据库原理配套课件Lesson-06.pptx_第1页
第1页 / 共126页
数据库原理配套课件Lesson-06.pptx_第2页
第2页 / 共126页
数据库原理配套课件Lesson-06.pptx_第3页
第3页 / 共126页
数据库原理配套课件Lesson-06.pptx_第4页
第4页 / 共126页
数据库原理配套课件Lesson-06.pptx_第5页
第5页 / 共126页
点击查看更多>>
资源描述

1、数据库原理数据库原理 孙大为孙大为中国地质大学中国地质大学 信息工程学院信息工程学院课程内容安排数据库编程数据库编程数据库安全性数据库安全性关系数据库标关系数据库标准语言准语言SQLSQL数据库完整性数据库完整性关系数据库关系数据库数据库设计数据库设计关系数据理论关系数据理论绪绪 论论关系查询处理关系查询处理和查询优化和查询优化数据库恢复技数据库恢复技术术并发控制并发控制第六讲关系数据理论v基于某个数据库管理系统设计数据库,如何基于数据库系统编程n第第6章章 关系数据理论关系数据理论n第第7章章 数据库设计数据库设计n第第8章章 数据库编程数据库编程第二篇第二篇 设计与应用开发篇设计与应用开发

2、篇本讲目标6.1 问题的提出问题的提出6.2 规范化6.3 数据依赖的公理系统*6.4 模式的分解6.5 小结6.1 问题的提出关系数据库逻辑设计n针对具体问题,如何构造一个适合于它的数据模式针对具体问题,如何构造一个适合于它的数据模式n数据库逻辑设计的工具数据库逻辑设计的工具关系数据库的规范化理论关系数据库的规范化理论问题的提出(续)v关系模式由五部分组成,是一个五元组: R(U, D, DOM, F)n关系名关系名R是符号化的元组语义是符号化的元组语义nU为一组属性为一组属性nD为属性组为属性组U中的属性所来自的域中的属性所来自的域nDOM为属性到域的映射为属性到域的映射nF为属性组为属性

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

4、约束关系是一个关系内部属性与属性之间的一种约束关系l通过属性间值的相等与否体现出来的数据间相互联系通过属性间值的相等与否体现出来的数据间相互联系n 是现实世界属性间相互联系的抽象是现实世界属性间相互联系的抽象n 是数据内在的性质是数据内在的性质n 是语义的体现是语义的体现问题的提出(续)v数据依赖的主要类型n函数依赖(函数依赖(Functional Dependency,简记为,简记为FD)n多值依赖(多值依赖(Multi-Valued Dependency,简记为,简记为MVD)问题的提出(续)v函数依赖普遍存在于现实生活中n描述一个学生关系,可以有学号、姓名、系名等属性。描述一个学生关系,

5、可以有学号、姓名、系名等属性。l一个学号只对应一个学生,一个学生只在一个系中学习一个学号只对应一个学生,一个学生只在一个系中学习l“学号学号”值确定后,学生的姓名及所在系的值就被唯一确值确定后,学生的姓名及所在系的值就被唯一确定。定。nSname=f(Sno),Sdept=f(Sno)l即即Sno函数决定函数决定SnamelSno函数决定函数决定Sdeptl记作记作SnoSname,SnoSdept 问题的提出(续)v例6.1 建立一个描述学校教务的数据库。涉及的对象包括:n学生的学号(学生的学号(Sno)n所在系(所在系(Sdept)n系主任姓名(系主任姓名(Mname)n课程号(课程号(C

6、no)n成绩(成绩(Grade)问题的提出(续)n假设学校教务的数据库模式用一个单一的关系模式假设学校教务的数据库模式用一个单一的关系模式Student来表示,则该关系模式的属性集合为:来表示,则该关系模式的属性集合为: U Sno, Sdept, Mname, Cno, Grade n现实世界的已知事实(语义):现实世界的已知事实(语义):l一个系有若干学生,一个系有若干学生, 但一个学生只属于一个系;但一个学生只属于一个系;l一个系只有一名(正职)负责人;一个系只有一名(正职)负责人;l一个学生可以选修多门课程,每门课程有若干学生选修;一个学生可以选修多门课程,每门课程有若干学生选修;l每

7、个学生学习每一门课程有一个成绩。每个学生学习每一门课程有一个成绩。 问题的提出(续)n由此可得到属性组由此可得到属性组U上的一组函数依赖上的一组函数依赖F: F=SnoSdept, Sdept Mname, (Sno, Cno) Grade SnoCnoSdeptMnameGrade问题的提出(续)关系模式Student中存在的问题:(1)数据冗余n浪费大量的存储空间浪费大量的存储空间l每一个系主任的姓名重复出现,重复次数与该系所有学每一个系主任的姓名重复出现,重复次数与该系所有学生的所有课程成绩出现次数相同。生的所有课程成绩出现次数相同。问题的提出(续)(2)更新异常(Update Anom

8、alies)n数据冗余数据冗余 ,更新数据时,维护数据完整性代价大。更新数据时,维护数据完整性代价大。l某系更换系主任后,必须修改与该系学生有关的每一个某系更换系主任后,必须修改与该系学生有关的每一个元组。元组。问题的提出(续)(3)插入异常(Insertion Anomalies)n如果一个系刚成立,尚无学生,则无法把这个系及其如果一个系刚成立,尚无学生,则无法把这个系及其系主任的信息存入数据库。系主任的信息存入数据库。问题的提出(续)(4)删除异常(Deletion Anomalies)n如果某个系的学生全部毕业了,如果某个系的学生全部毕业了, 则在删除该系学生信则在删除该系学生信息的同时

9、,把这个系及其系主任的信息也丢掉了。息的同时,把这个系及其系主任的信息也丢掉了。问题的提出(续)v结论nStudent关系模式不是一个好的模式。关系模式不是一个好的模式。n一个一个“好好”的模式应当不会发生插入异常、删除异常和更的模式应当不会发生插入异常、删除异常和更新异常,数据冗余应尽可能少。新异常,数据冗余应尽可能少。v原因n由存在于模式中的某些数据依赖引起的。由存在于模式中的某些数据依赖引起的。v解决方法n用规范化理论改造关系模式来消除其中不合适的数据依赖用规范化理论改造关系模式来消除其中不合适的数据依赖问题的提出(续)v把这个单一的模式分成三个关系模式:nS(Sno,Sdept,Sno

10、 Sdept);nSC(Sno,Cno,Grade,(Sno,Cno) Grade);nDEPT(Sdept,Mname,Sdept Mname);v这三个模式都不会发生插入异常、删除异常的问题,数据的冗余也得到了控制。第六章 关系数据理论6.1 问题的提出6.2 规范化规范化6.3 数据依赖的公理系统*6.4 模式的分解6.5 小结6.2 规范化6.2.1 函数依赖6.2.2 码6.2.3 范式6.2.4 2NF6.2.5 3NF6.2.6 BCNF6.2.7 多值依赖6.2.8 4NF6.2.9 规范化小结6.2.1 函数依赖1.函数依赖2.平凡函数依赖与非平凡函数依赖3.完全函数依赖与部

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

12、YX, 则记为则记为XY。若若Y不函数依赖于不函数依赖于X, 则记为则记为XY。函数依赖(续)SnoSnameSsexSageSdeptS1 张三张三男男20计算机系计算机系S1李四李四女女21自动化系自动化系S3王五王五男男20计算机系计算机系S4赵六赵六男男21计算机系计算机系S5田七田七男男20计算机系计算机系 . . . . . . . . . . . . . . .违背了违背了Sno Sname函数依赖(续)v由下面的关系表, 能否得出Sno SnameSnoSnameSsexSageSdeptS1 张三张三男男20计算机系计算机系S2李四李四女女21自动化系自动化系S3王五王五男男

13、20计算机系计算机系S4赵六赵六男男21计算机系计算机系S5田七田七男男20计算机系计算机系 . . . . . . . . . . . . . . .函数依赖不是指关系模式函数依赖不是指关系模式R的某个或某些关系实例满足的的某个或某些关系实例满足的约束条件,而是指约束条件,而是指R的所有关系实例均要满足的约束条件。的所有关系实例均要满足的约束条件。函数依赖(续)u函数依赖是语义范畴的概念,只能根据数据的语义来确定一个函数依赖。n例如例如“姓名姓名年龄年龄”这个函数依赖只有在不允许有同这个函数依赖只有在不允许有同名人的条件下成立名人的条件下成立2. 平凡函数依赖与非平凡函数依赖vXY,但YX则

14、称XY是非平凡的函数依赖。vXY,但YX 则称XY是平凡的函数依赖。对于任一关系模式,平凡函数依赖都是必然成立的,它对于任一关系模式,平凡函数依赖都是必然成立的,它不反映新的语义。不反映新的语义。若不特别声明,若不特别声明, 我们总是讨论非平凡函数依赖。我们总是讨论非平凡函数依赖。平凡函数依赖与非平凡函数依赖(续)v若XY,则X称为这个函数依赖的决定因素(Determinant)。v若XY,YX,则记作XY。v若Y不函数依赖于X,则记作XY。3. 完全函数依赖与部分函数依赖v定义6.2 在R(U)中,如果XY,并且对于X的任何一个真子集X, 都有 X Y, 则称Y对X完全函数依赖,记作X Y。

15、v若XY,但Y不完全函数依赖于X,则称Y对X部分函数依赖,记作X YFP完全函数依赖与部分函数依赖(续)v例 在关系SC(Sno, Cno, Grade)中,有:n 由于:由于:Sno Grade,Cno Grade, 因此:(Sno, Cno) Grade (Sno, Cno)Sno (Sno, Cno) CnoFPP4. 传递函数依赖v定义6.3 在R(U)中,如果XY(YX),YX,YZ,ZY, 则称Z对X传递函数依赖(transitive functional dependency)。记为:X Z。n注注: 如果如果YX, 即即XY,则,则Z直接依赖于直接依赖于X,而不是,而不是传递函

16、数依赖。传递函数依赖。n例例 在关系在关系Std(Sno, Sdept, Mname)中,有:中,有:Sno Sdept,Sdept Mname,Mname传递函数依赖于传递函数依赖于Sno传递传递6.2 规范化6.2.1 函数依赖6.2.2 码6.2.3 范式6.2.4 2NF6.2.5 3NF6.2.6 BCNF6.2.7 多值依赖6.2.8 4NF6.2.9 规范化小结6.2.2 码v定义6.4 设K为R中的属性或属性组合。若K U,则K称为R的一个候选码(Candidate Key)。n如果如果U部分函数依赖于部分函数依赖于K,即,即K U,则则K称为超码称为超码 (Surpkey)。

17、候选码是最小的超码,即)。候选码是最小的超码,即K的任意一个的任意一个真子集都不是候选码。真子集都不是候选码。v若关系模式R有多个候选码,则选定其中的一个做为主码(Primary key)。FP码(续)v主属性与非主属性n包含在任何一个候选码中的属性包含在任何一个候选码中的属性 ,称为主属性,称为主属性 (Prime attribute) n不包含在任何码中的属性称为非主属性(不包含在任何码中的属性称为非主属性(Nonprime attribute)或非码属性()或非码属性(Non-key attribute) v全码:整个属性组是码,称为全码(All-key) 码(续)例6.2S(Sno,

18、Sdept, Sage),单个属性Sno是码 SC(Sno, Cno, Grade)中,(Sno, Cno)是码例6.3 R(P,W,A) P:演奏者 W:作品 A:听众一个演奏者可以演奏多个作品某一作品可被多个演奏者演奏听众可以欣赏不同演奏者的不同作品 码为(P,W,A),即All-Key 码(续)v定义6.5 关系模式 R中属性或属性组X 并非 R的码,但 X 是另一个关系模式的码,则称 X 是R 的外部码(Foreign key)也称外码。nSC(Sno,Cno,Grade)中,中,Sno不是码不是码nSno是是 S(Sno,Sdept,Sage)的码,则的码,则Sno是是SC的外码的外

19、码 v主码与外部码一起提供了表示关系间联系的手段6.2 规范化6.2.1 函数依赖6.2.2 码6.2.3 范式6.2.4 2NF6.2.5 3NF6.2.6 BCNF6.2.7 多值依赖6.2.8 4NF6.2.9 规范化小结6.2.3 范式v范式是符合某一种级别的关系模式的集合。v关系数据库中的关系必须满足一定的要求。满足 不同程度要求的为不同范式。v范式的种类:第一范式第一范式(1NF)第二范式第二范式(2NF)第三范式第三范式(3NF)BC范式范式(BCNF)第四范式第四范式(4NF)第五范式第五范式(5NF)范式(续)v各种范式之间存在联系:n某一关系模式某一关系模式R为第为第n范式

20、,可简记为范式,可简记为RnNF。NF5NF4BCNFNF3NF2NF1v一个低一级范式的关系模式,通一个低一级范式的关系模式,通过模式分解(过模式分解(schema decomposition)可以转换为若)可以转换为若干个高一级范式的关系模式的集干个高一级范式的关系模式的集合,这种过程就叫合,这种过程就叫规范化规范化(normalization)。)。6.2 规范化6.2.1 函数依赖6.2.2 码6.2.3 范式6.2.4 2NF6.2.5 3NF6.2.6 BCNF6.2.7 多值依赖6.2.8 4NF6.2.9 规范化小结6.2.4 2NFv定义6.6 若关系模式R1NF,并且每一个

21、非主属性都完全函数依赖于任何一个候选码,则R2NFv例6.4 S-L-C(Sno,Sdept,Sloc,Cno,Grade), Sloc为学生的住处,并且每个系的学生住在同一个地方。S-L-C的码为(Sno,Cno)。函数依赖有n(Sno,Cno)GradenSnoSdept, (Sno,Cno)SdeptnSnoSloc, (Sno,Cno)SlocnSdeptSlocFPP2NF(续)SnoCnoGradeSdeptSlocn关系模式关系模式S-L-C不属于不属于2NFn非主属性非主属性Sdept、Sloc并不完全依赖于码并不完全依赖于码2NF(续)v一个关系模式不属于2NF,会产生以下问

22、题:n插入异常插入异常l如果插入一个新学生,但该生未选课,即该生无如果插入一个新学生,但该生未选课,即该生无Cno,由于插入元组时,必须给定码值,因此插入失败。由于插入元组时,必须给定码值,因此插入失败。n删除异常删除异常l如果如果S4只选了一门课只选了一门课C3,现在他不再选这门课,则删除,现在他不再选这门课,则删除C3后,整个元组的其他信息也被删除了。后,整个元组的其他信息也被删除了。n修改复杂修改复杂l如果一个学生选了多门课,则如果一个学生选了多门课,则Sdept,Sloc被存储了多被存储了多次。如果该生转系,则需要修改所有相关的次。如果该生转系,则需要修改所有相关的Sdept和和Slo

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

24、赖了SnoCnoGradeSnoSdeptSloc图图6.4 SC中的函数依赖中的函数依赖图图6.5 S-L中的函数依赖中的函数依赖6.2 规范化6.2.1 函数依赖6.2.2 码6.2.3 范式6.2.4 2NF6.2.5 3NF6.2.6 BCNF6.2.7 多值依赖6.2.8 4NF6.2.9 规范化小结 6.2.5 3NFv定义6.7 设关系模式R1NF,若R中不存在这样的码X、属性组Y及非主属性Z(Z Y), 使得XY,YZ成立,Y X不成立,则称R 3NF。n SC没有传递依赖,因此没有传递依赖,因此SC 3NFn S-L中中Sno Sdept( Sdept Sno), Sdept

25、Sloc,可得可得Sno Sloc。n 解决的办法是将解决的办法是将S-L分解成分解成lS-D(Sno,Sdept) 3NFlD-L(Sdept,Sloc) 3NF传递传递6.2 规范化6.2.1 函数依赖6.2.2 码6.2.3 范式6.2.4 2NF6.2.5 3NF6.2.6 BCNF6.2.7 多值依赖6.2.8 4NF6.2.9 规范化小结 6.2.6 BCNFvBCNF(Boyce Codd Normal Form)由Boyce和Codd提出,比3NF更进了一步。通常认为BCNF是修正的第三范式,有时也称为扩充的第三范式。v定义6.8 设关系模式R1NF,若X Y且Y X时X必含有

26、码,则RBCNF。v换言之,在关系模式R中,如果每一个决定属性集都包含候选码,则RBCNF。BCNF(续)vBCNF的关系模式所具有的性质n所有非主属性都完全函数依赖于每个候选码所有非主属性都完全函数依赖于每个候选码n所有主属性都完全函数依赖于每个不包含它的候选码所有主属性都完全函数依赖于每个不包含它的候选码n没有任何属性完全函数依赖于非码的任何一组属性没有任何属性完全函数依赖于非码的任何一组属性v如果一个关系数据库中的所有关系模式都属于BCNF,那么在函数依赖范畴内,它已实现了模式的彻底分解,达到了最高的规范化程度,消除了插入异常和删除异常。v例6.5考察关系模式C(Cno,Cname,Pc

27、no)n 它只有一个码它只有一个码Cno,没有任何属性对,没有任何属性对Cno部分依赖或部分依赖或传递依赖,所以传递依赖,所以C3NF。n 同时同时C中中Cno是唯一的决定因素,所以是唯一的决定因素,所以CBCNF。n 对于关系模式对于关系模式SC(Sno,Cno,Grade)可作同样分析。可作同样分析。BCNF(续)u例6.6 关系模式S(Sno,Sname,Sdept,Sage),n假定假定Sname也具有唯一性,那么也具有唯一性,那么S就有两个码,这两就有两个码,这两个码都由单个属性组成,彼此不相交。个码都由单个属性组成,彼此不相交。n其他属性不存在对码的传递依赖与部分依赖,所以其他属性

28、不存在对码的传递依赖与部分依赖,所以S3NF。n同时同时S中除中除Sno,Sname外没有其他决定因素,所以外没有其他决定因素,所以S也属于也属于BCNF。BCNF(续)v例6.7 关系模式SJP(S,J,P)中,S是学生,J表示 课程,P表示名次。每一个学生选修每门课程的 成绩有一定的名次,每门课程中每一名次只有一 个学生(即没有并列名次)。n 由语义可得到函数依赖:由语义可得到函数依赖: (S,J)P;(J,P)Sn (S,J)与与(J,P)都可以作为候选码。都可以作为候选码。n 关系模式中没有属性对码传递依赖或部分依赖,所以关系模式中没有属性对码传递依赖或部分依赖,所以 SJP3NF。n

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

30、TJ中的函数依赖中的函数依赖BCNF(续)v对于不是BCNF的关系模式,仍然存在不合适的地方。v非BCNF的关系模式也可以通过分解成为BCNF。例如STJ可分解为ST(S,T)与TJ(T,J),它们都是BCNF。BCNF(续)u3NF和BCNF是在函数依赖的条件下对模式分解所能达到的分离程度的测度。n一个模式中的关系模式如果都属于一个模式中的关系模式如果都属于BCNF,那么在函数,那么在函数依赖范畴内,它已实现了彻底的分离,已消除了插入依赖范畴内,它已实现了彻底的分离,已消除了插入和删除的异常。和删除的异常。n3NF的的“不彻底不彻底”性表现在可能存在主属性对码的部性表现在可能存在主属性对码的

31、部分依赖和传递依赖。分依赖和传递依赖。6.2 规范化6.2.1 函数依赖6.2.2 码6.2.3 范式6.2.4 2NF6.2.5 3NF6.2.6 BCNF6.2.7 多值依赖6.2.8 4NF6.2.9 规范化小结6.2.7 多值依赖例6.9设学校中某一门课程由多个教师讲授,他们使用相同的一套参考书。每个教员可以讲授多门课程,每种参考书可以供多门课程使用用关系模式用关系模式Teaching(C,T,B)来表示课程来表示课程C、教师、教师T和参和参考书考书B之间的关系。之间的关系。多值依赖(续)表表6.3 非规范化关系示例非规范化关系示例课程课程 C教员教员 T参考书参考书 B 物理物理 数

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

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

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

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

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

37、通物理学物物 理理李李 勇勇光学原理光学原理物物 理理李李 勇勇物理习题集物理习题集物物 理理王王 军军普通物理学普通物理学物物 理理王王 军军光学原理光学原理物物 理理王王 军军物理习题集物理习题集数数 学学李李 勇勇普通物理学普通物理学数数 学学李李 勇勇光学原理光学原理数数 学学李李 勇勇物理习题集物理习题集数数 学学张张 平平普通物理学普通物理学数数 学学张张 平平光学原理光学原理数数 学学张张 平平物理习题集物理习题集(4)修改操作复杂:某一修改操作复杂:某一门课要修改一本参考书,门课要修改一本参考书,该课程有多少名教师,该课程有多少名教师,就必须修改多少个元组。就必须修改多少个元组

38、。产生产生原因原因: 存在多值依赖存在多值依赖多值依赖(续)v定义6.9 设R(U)是属性集U上的一个关系模式。X,Y,Z是U的子集,并且Z=U-X-Y。关系模式R(U)中多值依赖XY成立,当且仅当对R(U)的任一关系r,给定的一对(x,z)值,有一组Y的值,这组值仅仅决定于x值而与z值无关。v例 Teaching(C, T, B) 对于C的每一个值,T有一组值与之对应,而不论B取何值。因此T多值依赖于C,即CT。 多值依赖(续)v多值依赖的另一个等价的定义在在R(U)的任一关系的任一关系r中,如果存在元组中,如果存在元组t,s使得使得tX=sX,那么就必然存在元组,那么就必然存在元组w,vr

39、,(,(w,v可以与可以与s,t相相同)同), 使得使得wX=vX=tX,而,而wY=tY,wZ=sZ,vY=sY,vZ=tZ(即交换(即交换s,t元组的元组的Y值所得的两值所得的两个新元组必在个新元组必在r中则中则Y多值依赖于多值依赖于X,记为,记为XY。这里。这里X,Y是是U的子集,的子集,Z=U-X-Y。多值依赖(续)v平凡多值依赖和非平凡的多值依赖n 若若XY,而,而Z,即,即Z为空,为空,则称则称XY为为平凡平凡的多值依赖的多值依赖。n 否则称否则称XY为为非平凡的多值依赖非平凡的多值依赖。多值依赖(续)WSCW1S1C1W1S1C2W1S1C3W1S2C1W1S2C2W1S2C3W

40、2S3C4W2S3C5W2S4C4W2S4C5例6.10关系模式WSC(W,S,C)中,W表示仓库,S 表示保管员,C 表示商品。假设每个仓库有若干个保管员,有若干种商品。每个保管员保管所在仓库的所有商品,每种商品被所有保管员保管。多值依赖(续)v按照语义对于W的每一个值Wi,S有一个完整的集合与之对应而不问C取何值。所以WS。v如图6.7所示n 对应对应W的某一个值的某一个值Wi的全部的全部S值记作值记作SWi(表示此仓库(表示此仓库工作的全部保管员)工作的全部保管员)n 全部全部C值记作值记作CWi(表示在此仓库中存放的所有商品)(表示在此仓库中存放的所有商品)n 应当有应当有SWi中的每

41、一个值和中的每一个值和CWi中的每一个中的每一个C值对应值对应n 于是于是SWi与与CWi之间正好形成一个完全二分图,因而之间正好形成一个完全二分图,因而WS。多值依赖(续)u由于C与S的完全对称性,必然有WC成立。图图6.7 WS且且WC多值依赖(续)u多值依赖的性质(1)多值依赖具有对称性。)多值依赖具有对称性。即若即若XY,则,则XZ,其中,其中ZUXYl多值依赖的对称性可以用完全二分图直观地表示出来。多值依赖的对称性可以用完全二分图直观地表示出来。l从从例例6.10 容易看出,因为每个保管员保管所有商品,容易看出,因为每个保管员保管所有商品,同时每种商品被所有保管员保管,显然若同时每种

42、商品被所有保管员保管,显然若WS,必然,必然有有WC。多值依赖(续)(2)多值依赖具有传递性。即若)多值依赖具有传递性。即若XY,YZ, 则则 XZ -Y。(3)函数依赖是多值依赖的特殊情况。即若)函数依赖是多值依赖的特殊情况。即若XY,则,则 XY。(4)若)若XY,XZ,则,则XYZ。(5)若)若XY,XZ,则,则XYZ。(6)若)若XY,XZ,则,则XY-Z,XZ -Y。多值依赖(续)v多值依赖与函数依赖的区别(1)多值依赖的有效性与属性集的范围有关)多值依赖的有效性与属性集的范围有关l若若XY在在U上成立,则在上成立,则在W(XY W U)上一定成)上一定成立;反之则不然,即立;反之则

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

44、在中,元组在X和和Y上的值满上的值满足定义足定义6.l,则函数依赖,则函数依赖XY在任何属性集在任何属性集W(XY W U)上成立。上成立。多值依赖(续)(2)若函数依赖)若函数依赖XY在在R (U)上成立,则对于任何上成立,则对于任何Y Y均有均有XY 成立。多值依赖成立。多值依赖XY若在若在R(U)上成立,上成立,不能断言对于任何不能断言对于任何Y Y有有XY 成立。成立。多值依赖(续) 例如,关系例如,关系R(A,B,C,D),ABC成立,当然也有成立,当然也有AD成立。有成立。有R的一个关系实例,在此实例上的一个关系实例,在此实例上AB是不成立的。是不成立的。ABCDa1b1c1d1a

45、1b1c1d2a1b2c2d1a1b2c2d2 表表6.6 R的一个实例的一个实例6.2 规范化6.2.1 函数依赖6.2.2 码6.2.3 范式6.2.4 2NF6.2.5 3NF6.2.6 BCNF6.2.7 多值依赖6.2.8 4NF6.2.9 规范化小结6.2.8 4NFv定义6.10 关系模式R1NF,如果对于R的每个非平凡多值依赖XY(Y X),X都含有码,则R4NF。v4NF就是限制关系模式的属性之间不允许有非平凡且非函数依赖的多值依赖。4NF所允许的非平凡多值依赖实际上是函数依赖。4NF(续)v如果一个关系模式是4NF, 则必为BCNF。v在例6.10的WSC中,W S, WC

46、,他们都是非平凡多值依赖。而W不是码,关系模式WSC的码是(W,S,C),即All-key,因此WSC 4NF。v可以把WSC分解成WS(W,S),WC(W,C), WS4NF,WC4NF。6.2 规范化6.2.1 函数依赖6.2.2 码6.2.3 范式6.2.4 2NF6.2.5 3NF6.2.6 BCNF6.2.7 多值依赖6.2.8 4NF6.2.9 规范化小结6.2.9 规范化小结v在关系数据库中,对关系模式的基本要求是满足第一范式。v规范化程度过低的关系不一定能够很好地描述现实世界n 可能存在插入异常、删除异常、修改复杂、数据冗余可能存在插入异常、删除异常、修改复杂、数据冗余等问题等

47、问题n 解决方法就是对其进行规范化,转换成高级范式。解决方法就是对其进行规范化,转换成高级范式。规范化小结(续)v一个低一级范式的关系模式,通过模式分解可以转换为若干个高一级范式的关系模式集合,这种过程就叫关系模式的规范化。v关系数据库的规范化理论是数据库逻辑设计的工具。规范化小结(续)v规范化的基本思想n 是逐步消除数据依赖中不合适的部分,使模式中的各关是逐步消除数据依赖中不合适的部分,使模式中的各关系模式达到某种程度的系模式达到某种程度的“分离分离”。n 即采用即采用“一事一地一事一地”的模式设计原则的模式设计原则l让一个关系描述一个概念、一个实体或者实体间的一种联让一个关系描述一个概念、

48、一个实体或者实体间的一种联系。系。l若多于一个概念就把它若多于一个概念就把它“分离分离”出去。出去。n 因此因此 规范化实质上是概念的单一化。规范化实质上是概念的单一化。规范化小结(续)关系模式规范化的基本步骤 1NF 消除非主属性对码的部分函数依赖消除决定因素 2NF非码的非平凡 消除非主属性对码的传递函数依赖函数依赖 3NF 消除主属性对码的部分和传递函数依赖 BCNF 消除非平凡且非函数依赖的多值依赖 4NF图图6.8 规范化过程规范化过程规范化小结(续)v不能说规范化程度越高的关系模式就越好。n必须对现实世界的实际情况和用户应用需求作进一步必须对现实世界的实际情况和用户应用需求作进一步

49、分析,确定一个合适的、能够反映现实世界的模式。分析,确定一个合适的、能够反映现实世界的模式。n上面的规范化步骤可以在其中任何一步终止。上面的规范化步骤可以在其中任何一步终止。第六章 关系数据理论6.1 问题的提出问题的提出6.2 规范化规范化6.3 数据依赖的公理系统数据依赖的公理系统*6.4 模式的分解6.5 小结6.3 数据依赖的公理系统v定义6.11 对于满足一组函数依赖F的关系模式 R ,其任何一个关系r,若函数依赖XY都成立(即r中任意两元组t、s,若tX=sX,则 tY=sY),则称F逻辑蕴涵X Y。数据依赖的公理系统(续)vArmstrong公理系统n一套推理规则,是模式分解算法

50、的理论基础一套推理规则,是模式分解算法的理论基础n用途用途l 求给定关系模式的码求给定关系模式的码l 从一组函数依赖求得蕴涵的函数依赖从一组函数依赖求得蕴涵的函数依赖数据依赖的公理系统(续)vArmstrong公理系统 设U为属性集总体,F是U上的一组函数依赖, 于是有关系模式R 。对R 来说有以下的推理规则:nA1 自反律(自反律(reflexivity rule):若):若Y X U,则,则X Y 为为F所蕴涵。所蕴涵。nA2 增广律(增广律(augmentation rule):若):若XY为为F所蕴所蕴涵,且涵,且Z U,则,则XZYZ 为为F所蕴涵。所蕴涵。nA3 传递律(传递律(t

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 办公、行业 > 各类PPT课件(模板)
版权提示 | 免责声明

1,本文(数据库原理配套课件Lesson-06.pptx)为本站会员(三亚风情)主动上传,163文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。
2,用户下载本文档,所消耗的文币(积分)将全额增加到上传者的账号。
3, 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(发送邮件至3464097650@qq.com或直接QQ联系客服),我们立即给予删除!


侵权处理QQ:3464097650--上传资料QQ:3464097650

【声明】本站为“文档C2C交易模式”,即用户上传的文档直接卖给(下载)用户,本站只是网络空间服务平台,本站所有原创文档下载所得归上传人所有,如您发现上传作品侵犯了您的版权,请立刻联系我们并提供证据,我们将在3个工作日内予以改正。


163文库-Www.163Wenku.Com |网站地图|