




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、返回返回第第4章章 关系数据库理论关系数据库理论返回返回4.3 范式范式 规范化的基本思想是消除关系模式中的数据冗余,消除数据依赖规范化的基本思想是消除关系模式中的数据冗余,消除数据依赖中的不合适的部分,解决数据插入、删除时发生异常现象。中的不合适的部分,解决数据插入、删除时发生异常现象。 这就要求关系数据库设计出来的关系模式要满足一定的条件。这就要求关系数据库设计出来的关系模式要满足一定的条件。 我们把关系数据库的规范化过程中为不同程度的规范化要求设立我们把关系数据库的规范化过程中为不同程度的规范化要求设立的不同标准称为范式的不同标准称为范式Normal FormNormal Form)。)
2、。 由于规范化的程度不同,就产生了不同的范式。由于规范化的程度不同,就产生了不同的范式。 满足最基本规范化要求的关系模式叫第一范式,满足最基本规范化要求的关系模式叫第一范式, 在第一范式中进一步满足一些要求为第二范式,在第一范式中进一步满足一些要求为第二范式, 以此类推就产生了第三、四范式等概念。以此类推就产生了第三、四范式等概念。 每种范式都规定了一些限制约束条件。每种范式都规定了一些限制约束条件。 最重要的是最重要的是3NF3NF和和BCNFBCNF。这是进行规范化的主要目标。这是进行规范化的主要目标。 返回返回范式的概念最早由范式的概念最早由E.F.CoddE.F.Codd提出。提出。从
3、从19711971年起,年起,CoddCodd相继提出了关系的三级规范相继提出了关系的三级规范化形式,即第一范式化形式,即第一范式1NF1NF)、第二范式)、第二范式2NF2NF)、)、第三范式第三范式3NF3NF)。)。19741974年,年,CoddCodd和和BoyceBoyce以共同提出了一个新的以共同提出了一个新的范式的概念,即范式的概念,即Boyce-CoddBoyce-Codd范式,简称范式,简称BCBC范式。范式。19761976年年FaginFagin提出了第四范式,提出了第四范式,后来又有人定义了第五范式。后来又有人定义了第五范式。至此在关系数据库规范中建立了一个范式系列:
4、至此在关系数据库规范中建立了一个范式系列:1NF,2NF,3NF,BCNF,4NF,5NF,1NF,2NF,3NF,BCNF,4NF,5NF,一级比一级有更严一级比一级有更严格的要求。格的要求。各个范式之间的联系可以表示为:各个范式之间的联系可以表示为:5NF 4NF BCNF 3NF 2NF 1NF5NF 4NF BCNF 3NF 2NF 1NF如图如图4.34.3所示。所示。 返回返回图图4.3 4.3 各种范式之间的关系各种范式之间的关系1NF,2NF,3NF,BCNF,4NF,5NF,1NF,2NF,3NF,BCNF,4NF,5NF,一级比一级有更严一级比一级有更严格的要求。格的要求。
5、下面逐一介绍各级范式及其规范化。下面逐一介绍各级范式及其规范化。 返回返回4.3.1 4.3.1 第一范式第一范式第一范式第一范式First Normal FormFirst Normal Form是最基本的规是最基本的规范形式,即关系中每个属性都是不可再分的简单范形式,即关系中每个属性都是不可再分的简单项。项。定义定义4.4 4.4 如果关系模式如果关系模式R R,其所有的属性均为简,其所有的属性均为简单属性,即每个属性都城是不可再分的,则称单属性,即每个属性都城是不可再分的,则称R R属于第一范式,简称属于第一范式,简称1NF1NF,记作,记作R R1NF1NF。在第在第2 2章讨论关系的
6、性质时,我们把满足这个条章讨论关系的性质时,我们把满足这个条件的关系称为规范化关系。件的关系称为规范化关系。在关系数据库系统中只讨论规范化的关系,凡是在关系数据库系统中只讨论规范化的关系,凡是非规范化的关系模式必须化成规范化的关系。非规范化的关系模式必须化成规范化的关系。在非规范化的关系中去掉组合项就能化成规范化在非规范化的关系中去掉组合项就能化成规范化的关系。的关系。每个规范化的关系都属于每个规范化的关系都属于1NF1NF,这也是它之所以,这也是它之所以称为称为“第一的原因。第一的原因。 返回返回然而,一个关系模式仅仅属于第一范式是不然而,一个关系模式仅仅属于第一范式是不适用的。适用的。在在
7、4.14.1节中给出的关系模式节中给出的关系模式SCDSCD属于第一范式,属于第一范式,但其具有大量的数据冗余,具有插入异常、删但其具有大量的数据冗余,具有插入异常、删除异常、更新异常等弊端。除异常、更新异常等弊端。为什么会存在这种问题呢?为什么会存在这种问题呢?让我们分析一下让我们分析一下SCDSCD中的函数依赖关系,它的中的函数依赖关系,它的关系键是关系键是SNOSNO,CNOCNO的属性组合,所以有:的属性组合,所以有: (SNOSNO,CNOCNO) SCORESCORESNOSNSNOSN,(,(SNOSNO,CNOCNO) SNSNSNOAGESNOAGE,(,(SNOSNO,CN
8、OCNO) AGEAGESNODEPTSNODEPT,(,(SNOSNO,CNOCNO) DEPTDEPTSNO MNSNO MN,(,(SNOSNO,CNOCNO) MN MN fppppt返回返回我们可以用函数信赖图表示以上函数依赖关系,如图我们可以用函数信赖图表示以上函数依赖关系,如图4.44.4所示。所示。 SNMNSCORESNOCNOPPf由此可见,在SCD中,既存在完全函数依赖,又存在部分函数依赖和传递函数依赖。这种情况往往在数据库中是不允许的,也正是由于关系中存在着复杂的函数依赖,才导致数据操作中出现了种弊端。克服这些弊端的方法是用投影运算将关系分解,去掉过于复杂的函数依赖关系
9、,向更高一级的范式进行转换。 返回返回4.3.2 4.3.2 第二范式第二范式4.3.2.1 4.3.2.1 第二范式的定义第二范式的定义定义定义4.5 4.5 如果关系模式如果关系模式R R1NF1NF,且每个非主属,且每个非主属性都完全函数依赖于性都完全函数依赖于R R的每个关系键,则称的每个关系键,则称R R属于属于第二范式第二范式Second Normal FormSecond Normal Form),简称),简称2NF2NF,记作记作R R2NF2NF。在关系模式在关系模式SCDSCD中,中,SNOSNO,CNOCNO为主属性,为主属性,AGEAGE,DEPTDEPT,MNMN,M
10、NMN,SCORESCORE均为非主属性,经上述分均为非主属性,经上述分析,存在非主属性对关系键的部分函数依赖,所析,存在非主属性对关系键的部分函数依赖,所以以SCDSCD2NF2NF。而如图而如图4.24.2所示的由所示的由SCDSCD分解的三个关系模式分解的三个关系模式S S,D D,SCSC,其中,其中S S的关系键为的关系键为SNOSNO,D D的关系键为的关系键为DEPTDEPT,都是单属性,不可能存在部分函数依赖。都是单属性,不可能存在部分函数依赖。而对于而对于SCSC,(,(SNOSNO,CNOCNO) SCORESCORE。所以。所以SCDSCD分分解后,消除了非主属性对关系键
11、的部分函数依赖,解后,消除了非主属性对关系键的部分函数依赖,S S,D D,SCSC均属于均属于2NF2NF。 f返回返回又如在又如在2.4.22.4.2中,讲述全码的概念时给出的关中,讲述全码的概念时给出的关系模式系模式TCSTCST T,C C,S S),),一个教师可以讲授多门课程,一门课程可以为一个教师可以讲授多门课程,一门课程可以为多个教师讲授,多个教师讲授,同样一个学生可以选听多门课程,一门课程可同样一个学生可以选听多门课程,一门课程可以为多个学生选听,以为多个学生选听,(T,C,S)(T,C,S)三个属性的组合是关系键,三个属性的组合是关系键,T,C,ST,C,S都是都是主属性,
12、而无非主属性,所以也就不可能存在主属性,而无非主属性,所以也就不可能存在非主属性对关系键的部分函数依赖,非主属性对关系键的部分函数依赖,TCSTCS2NF2NF。经以上分析,可以得到两个结论:经以上分析,可以得到两个结论:1 1从从1NF1NF关系中消除非主属性对关系键的部分关系中消除非主属性对关系键的部分函数依赖,则可得到函数依赖,则可得到2NF2NF关系。关系。2 2如果如果R R的关系键为单属性,或的关系键为单属性,或R R的全体属性的全体属性均为主属性,则均为主属性,则R R2NF2NF。 返回返回4.3.2.2 2NF4.3.2.2 2NF规范化规范化2NF2NF规范化是指把规范化是
13、指把1NF1NF关系模式通过投影分解转换关系模式通过投影分解转换成成2NF2NF关系模式的集合。关系模式的集合。分解时遵循的基本原则就是分解时遵循的基本原则就是“一事一地一事一地”,让一,让一个关系只描述一个实体或者实体间的联系。如果个关系只描述一个实体或者实体间的联系。如果多于一个实体或联系,则进行投影分解。多于一个实体或联系,则进行投影分解。下面以关系模式下面以关系模式SCDSCD为例,来说明为例,来说明2NF2NF规范化的过规范化的过程程例例4.1 4.1 将将SCD(SNO,SN,AGE,DEPT,MN,CNO,SCORE)SCD(SNO,SN,AGE,DEPT,MN,CNO,SCOR
14、E)规范到规范到2NF2NF。由由SNOSNSNOSN,SNOAGESNOAGE,SNODEPTSNODEPT,(,(SNOSNO,CNOCNO) SCORESCORE,可以判断,关系,可以判断,关系SCDSCD至少描述了两个实体,至少描述了两个实体,一个为学生实体,属性有一个为学生实体,属性有SNOSNO、SNSN、AGEAGE、DEPTDEPT、MNMN;另一个是学生与课程的联系选课),属性有另一个是学生与课程的联系选课),属性有SNOSNO、CNOCNO和和SCORESCORE。根据分解的原则,我们可以将根据分解的原则,我们可以将SCDSCD分解成如下两分解成如下两个关系,如图个关系,如
15、图4.54.5所示。所示。 f返回返回SD(SNO,SN,AGE,DEPT,MN),描述学生实体;SC(SNO,CNO,SCORE),描述学生与课程的联系。SD SNOSNAGEDEPTMNS1赵亦17计算机刘伟S2钱尔18信息王平S3孙珊20信息王平S4李思21自动化刘伟SC SC SNOCNOSCORES1C190S1C285S2C557S2C680S2C7 S2C570S3C10S3C270S3C485S4C193图4.5 关系SD和SC 返回返回 对于分解后的两个关系对于分解后的两个关系SDSD和和SCSC,主键分别为,主键分别为SNOSNO和和SNOSNO,CNOCNO),非主属性对
16、主键完全函数依赖。因此,),非主属性对主键完全函数依赖。因此,SDSD2NF2NF,SCSC2NF2NF,而且前面已经讨论,而且前面已经讨论,SCDSCD的这种分的这种分解没有丢失任何信息,具有无损连接性。解没有丢失任何信息,具有无损连接性。 分解后,分解后,SDSD和和SCSC的函数依赖分别如图的函数依赖分别如图4.64.6和和4.74.7所示。所示。 SNOSNSNOCNOSCOREAGEDEPTMN图图4.6 SD4.6 SD中的函数依赖关系中的函数依赖关系 图图4.7 SC4.7 SC中的函数依赖关系中的函数依赖关系 返回返回 1NF1NF的关系模式经过投影分解转换成的关系模式经过投影
17、分解转换成2NF2NF后,消除了一后,消除了一些数据冗余。些数据冗余。 分析图分析图4.54.5中中SDSD和和SCSC中的数据,可以看出,它们存储的中的数据,可以看出,它们存储的冗余度比关系模式冗余度比关系模式SCDSCD有了较大辐度的降低。有了较大辐度的降低。 学生的姓名、年龄不需要重复存储多次。学生的姓名、年龄不需要重复存储多次。 这样便可在一定程度上避免数据更新所造成的数据不这样便可在一定程度上避免数据更新所造成的数据不一致性的问题。一致性的问题。 由于把学生的基本信息与选课信息分开存储,则学生由于把学生的基本信息与选课信息分开存储,则学生基本信息因没选课而不能插入的问题得到了解决,插
18、基本信息因没选课而不能插入的问题得到了解决,插入异常现象得到了部分改善。入异常现象得到了部分改善。 同样,如果某个学生不再选修同样,如果某个学生不再选修C1C1课程,只在选课关系课程,只在选课关系SCSC中删去该该学生选修中删去该该学生选修C1C1的记录即可,而的记录即可,而SDSD中有关该中有关该学生的其它信息不会受到任何影响,也解决了部分删学生的其它信息不会受到任何影响,也解决了部分删除异常问题。除异常问题。 因此可以说关系模式因此可以说关系模式SDSD和和SCSC在性能上比在性能上比SCDSCD有了显著提有了显著提高。高。 返回返回下面对下面对2NF2NF规范化作形式化的描述。规范化作形
19、式化的描述。设关系模式设关系模式R RX,Y,ZX,Y,Z),),R R1NF1NF,但但R R2NF2NF,其中,其中,X X是键属性,是键属性,Y Y,Z Z是非键属性,且存在部分函数依赖,是非键属性,且存在部分函数依赖,X X Y Y。设。设X X可表示为可表示为X1X1、X2X2,其中,其中X1 YX1 Y。则。则R RX X,Y Y,Z Z可以分解可以分解为为RX1RX1,YY和和RXRX,ZZ。因为因为X1YX1Y,所以,所以R(XR(X,Y Y,Z)=RX1Z)=RX1,YY* *RX1RX1,X2X2,Z=RX1Z=RX1,YY* *RXRX,ZZ,即,即R R等于其投影等于其
20、投影RX1RX1,YY和和XX,ZZ在在X1X1上的自然连接,上的自然连接,R R的分解具有的分解具有无损连接性。无损连接性。由于由于X1 YX1 Y,因此,因此RX1RX1,YY2NF2NF。若若RXRX,Z Z 2NF2NF,可以按照上述方,可以按照上述方法继续进行投影分解,直到将法继续进行投影分解,直到将RXRX,ZZ分解为属于分解为属于2NF2NF关系的集合,且这关系的集合,且这种分解必定是有限的。种分解必定是有限的。 pff返回返回4.3.2.3 2NF4.3.2.3 2NF的缺点的缺点2NF2NF的关系模式解决了的关系模式解决了1NF1NF中存在的一些问题,中存在的一些问题,2NF
21、2NF规范化的程度比规范化的程度比1NF1NF前进了一步,但前进了一步,但2NF2NF的关系模的关系模式在进行数据操作时,仍然存在着一些问题:式在进行数据操作时,仍然存在着一些问题:1 1数据冗余。每个系名和系主任的名字存储的次数据冗余。每个系名和系主任的名字存储的次数等于该系的学生人数。数等于该系的学生人数。2 2插入异常。当一个新系没有招生时,有关该系插入异常。当一个新系没有招生时,有关该系的信息无法插入。的信息无法插入。3 3删除异常。某系学生全部毕业而没有招生时,删除异常。某系学生全部毕业而没有招生时,删除全部学生的记录也随之删除了该系的有关信删除全部学生的记录也随之删除了该系的有关信
22、息。息。4 4更新异常。更换系主任时,仍需改动较多的学更新异常。更换系主任时,仍需改动较多的学生记录。生记录。之所以存在这些问题,是由于在之所以存在这些问题,是由于在SCDSCD中存在着非主中存在着非主属性对主键的传递依赖。属性对主键的传递依赖。分析分析SCDSCD中的函数依赖关系,中的函数依赖关系,SNOSNSNOSN,SNOAGESNOAGE,SNODEPTSNODEPT,DEPTMNDEPTMN,SNO MNSNO MN,非主属性,非主属性MNMN对主键对主键SNOSNO传递依赖。传递依赖。为此,对关系模式为此,对关系模式SCDSCD还需进一步简化,消除这种还需进一步简化,消除这种传递依
23、赖,得到传递依赖,得到3NF3NF。 t返回返回4.3.3 4.3.3 第三范式第三范式4.3.3.1 4.3.3.1 第三范式的定义第三范式的定义定义定义4.6 4.6 如果关系模式如果关系模式R R2NF2NF,且每个非,且每个非主属性都不传递依赖于主属性都不传递依赖于R R的每个关系键,则的每个关系键,则称称R R属于第三范式属于第三范式Third Normal FormThird Normal Form),),简称简称3NF3NF,记作,记作R R3NF3NF。第三范式具有如下性质:第三范式具有如下性质:1 1如果如果R R3NF3NF,则,则R R也是也是2NF2NF。返回返回2 2
24、如果如果R R2NF2NF,则,则R R不一定是不一定是3NF3NF。例如,我们前面由关系模式例如,我们前面由关系模式SCDSCD分解而得到的分解而得到的SDSD和和SCSC都为都为2NF2NF,其中,其中,SCSC3NF3NF,但在,但在SDSD中存在着中存在着非主属性非主属性MNMN对主键对主键SNOSNO传递依赖,传递依赖,SD3NFSD3NF。对于。对于SDSD,应该进一步进行分解,使其转换成应该进一步进行分解,使其转换成3NF3NF。 4.3.3.2 3NF4.3.3.2 3NF规范化规范化3NF3NF规范化是指把规范化是指把2NF2NF关系模式通过投影分解转换关系模式通过投影分解转
25、换成成3NF3NF关系模式的集合。关系模式的集合。和和2NF2NF的规范化时遵循的原则相同,即的规范化时遵循的原则相同,即“一事一一事一地地”,让一个关系只描述一个实体或者实体间的,让一个关系只描述一个实体或者实体间的联系。联系。下面以下面以2NF2NF关系模式关系模式SDSD为例,来说明为例,来说明3NF3NF规范化的规范化的过程。过程。 返回返回例例4.24.2将将SD(SNO,SN,AGE,DEPT,MN)SD(SNO,SN,AGE,DEPT,MN)规范到规范到3NF3NF。 分析分析SDSD的属性组成,可以判断,关系的属性组成,可以判断,关系SDSD实际上实际上描述了两个实体:描述了两
26、个实体: 一个为学生实体,属性有一个为学生实体,属性有SNOSNO,SNSN,AGEAGE,DEPTDEPT; 另一个是系的实体,其属性另一个是系的实体,其属性DEPTDEPT和和MNMN。根据分解的原则,我们可以将根据分解的原则,我们可以将SDSD分解成如下两个分解成如下两个关系,如图关系,如图4.84.8所示。所示。 S(SNO,SN,AGE,DEPT)S(SNO,SN,AGE,DEPT),描述学生实体;,描述学生实体; D(DEPTD(DEPT,MN)MN),描述系的实体。,描述系的实体。 返回返回S DS DDEPTMN计算机刘伟信息王平自动化刘伟SNOSNAGEDEPTS1赵亦17计
27、算机S2钱尔18信息S3孙珊20信息S4李思21自动化对于分解后的两个关系S和D,主键分别为SNO和DEPT,不存在非主属性对主键的传递函数依赖。因此,S3NF,D3NF。图图4.8 4.8 关系关系S S和和D D 返回返回 分解后,分解后,S S和和D D的函数依赖分别如图的函数依赖分别如图4.94.9和和4.104.10所示。所示。SNOSNDEPTAGEDEPTMN图图4.9 S4.9 S中的函数依赖关系图中的函数依赖关系图图图4.10 D4.10 D中的函数依赖关系图中的函数依赖关系图由以上两图可以看出,关系模式SD由2NF分解为3NF后,函数依赖关系变得更加简单,既没有非主属性对键
28、的部分依赖,也没有非主属性对键的传递依赖,解决了2NF中存在的四个问题。返回返回1数据冗余降低。系主任的名字存储的次数与该系的学生人数无关,只在关系D中存储一次。2不存在插入异常。当一个新系没有学生时,该系的信息可以直接插入到关系D中,而与学生关系S无关。3不存在删除异常。要删除某系的全部学生而仍然保留该系的有关信息时,可以只删除学生关系S中的相关学生记录,而不影响系关系D中的数据。 4不存在更新异常。更换系主任时,只需修改关系D中一个相应元组的MN属性值,从而不会出现数据的不一致现象。SCD规范到3NF后,所存在的异常现象已经全部消失。但是,3NF只限制了非主属性对键的依赖关系,而没有限制主
29、属性对键的依赖关系。如果发生了这种依赖,仍有可能存在数据冗余、插入异常、删除异常和修改异常。这时,则需对3NF进一步规范化,消除主属性对键的依赖关系,为了解决这种问题,Boyce与Codd共同提出了一个新范式的定义,这就是Boyce-Codd范式,通常简称BCNF或BC范式。它弥补了3NF的不足。返回返回4.3.4 BC4.3.4 BC范式范式4.3.4.1 BC4.3.4.1 BC范式的定义范式的定义定义定义4.7 4.7 如果关系模式如果关系模式R R1NF1NF,且所有的,且所有的函数依赖函数依赖XYXYY XY X), ,决定因素决定因素X X都包都包含了含了R R的一个候选键,则称的
30、一个候选键,则称R R属于属于BCBC范式范式Boyce-Codd Normal FormBoyce-Codd Normal Form),记作),记作R RBCNFBCNF。BCNFBCNF具有如下性质:具有如下性质:1 1满足满足BCNFBCNF的关系将消除任何属性主属的关系将消除任何属性主属性或非主属性对键的部分函数依赖和性或非主属性对键的部分函数依赖和传递函数依赖。也就是说,如果传递函数依赖。也就是说,如果R RBCNFBCNF,则则R R也是也是3NF3NF。证明:采用反证法。设证明:采用反证法。设R R不是不是3NF3NF。则必然。则必然存在如下条件的函数依赖,存在如下条件的函数依赖
31、,XYXYY Y X X),),YZYZ,其中,其中X X是键属性,是键属性,Y Y是任意属是任意属性组,性组,Z Z是非主属性,是非主属性,Z YZ Y,这样,这样YZYZ函函数依赖的决定因素数依赖的决定因素Y Y不包含候选键,这与不包含候选键,这与BCNFBCNF范式的定义相矛盾,所以如果范式的定义相矛盾,所以如果R RBCNFBCNF,则,则R R也是也是3NF3NF。 返回返回2 2如果如果R R3NF3NF,则,则R R不一定是不一定是BCNFBCNF。现举例说明。设关系模式现举例说明。设关系模式SNCSNCSNOSNO,SNSN,CN0CN0,SCORESCORE),其中),其中S
32、NOSNO代代表学号,表学号,SNSN代表学生姓名并假设没有重名,代表学生姓名并假设没有重名,CNOCNO代表课程号,代表课程号,SCORESCORE代表成绩。可以判定,代表成绩。可以判定,SNCSNC有两个候选键有两个候选键SNOSNO,CNOCNO和和SNSN,CNOCNO),其函数依赖如下:),其函数依赖如下: SNO SNSNO SN(SNOSNO,CNOCNO)SCORESCORE(SNSN,CNOCNO)SCORESCORE。唯一的非主属性唯一的非主属性SCORESCORE对键不存在部分函数依赖,也不存在传递函数对键不存在部分函数依赖,也不存在传递函数依赖。所以依赖。所以SNCSN
33、C3NF3NF。但是,因为但是,因为SNO SNSNO SN,即决定因素,即决定因素SNOSNO或或SNSN不包含候选键,从另一个不包含候选键,从另一个角度说,存在着主属性对键的部分函数依赖:角度说,存在着主属性对键的部分函数依赖: (SNOSNO,CNOCNO) SNSN,(,(SNSN,CNOCNO) SNOSNO,所以,所以SNCSNC不是不是BCNFBCNF。正是存在着这种主属性对键的部分函数依赖关系,造成了关系正是存在着这种主属性对键的部分函数依赖关系,造成了关系SNCSNC中中存在着较大的数据冗余,学生姓名的存储次数等于该生所选的课存在着较大的数据冗余,学生姓名的存储次数等于该生所
34、选的课程数。从而会引起修改异常。程数。从而会引起修改异常。比如,当要更改某个学生的姓名时,则必须搜索出现该姓名的每个比如,当要更改某个学生的姓名时,则必须搜索出现该姓名的每个学生记录,并对其姓名逐一修改,这样容易造成数据的不一致问学生记录,并对其姓名逐一修改,这样容易造成数据的不一致问题。题。解决这一问题的办法仍然是通过投影分解进一步提高解决这一问题的办法仍然是通过投影分解进一步提高SNCSNC的范式等级,的范式等级,将将SNCSNC规范到规范到BCNFBCNF。 p p返回返回4.3.4.2 BCNF4.3.4.2 BCNF规范化规范化BCNFBCNF规范化是指把规范化是指把3NF3NF关系
35、模式通过投影分解转关系模式通过投影分解转换成换成BCNFBCNF关系模式的集合。关系模式的集合。下面以下面以3NF3NF关系模式关系模式SNCSNC为例,来说明为例,来说明BCNFBCNF规范化规范化的过程。的过程。例例4.34.3将将SNC(SNO,SN,CNOSNC(SNO,SN,CNO,SCORE)SCORE)规范到规范到BCNFBCNF。分析分析SNCSNC数据冗余的原因,是因为在这一个关系数据冗余的原因,是因为在这一个关系中存在两个实体,一个为学生实体,属性有中存在两个实体,一个为学生实体,属性有SNOSNO、SNSN;另一个是选课实体,属性有;另一个是选课实体,属性有SNOSNO、
36、CNOCNO和和SCORESCORE。根据分解的原则,我们可以将根据分解的原则,我们可以将SNCSNC分解成如下两分解成如下两个关系:个关系:S1(SNO,SN)S1(SNO,SN),描述学生实体;,描述学生实体;S2(SNO,CNO,SCORE)S2(SNO,CNO,SCORE),描述学生与课程的联系。,描述学生与课程的联系。对于对于S1S1,有两个候选键,有两个候选键SNOSNO和和SNSN,对于对于S2S2,主键为,主键为SNOSNO,CNOCNO)。)。在这两个关系中,无论主属性还是非主属性都不在这两个关系中,无论主属性还是非主属性都不存在对键的部分依赖和传递依赖,存在对键的部分依赖和
37、传递依赖,S1S1BCNFBCNF,S2S2BCNFBCNF。 返回返回分解后,分解后,S1S1和和S2S2的函数依赖分别如图的函数依赖分别如图4.114.11和和4.124.12所示。所示。SNOSNSNOCNOSCORE图图4.11 S14.11 S1中的函数依赖关系中的函数依赖关系 图图4.12 S24.12 S2中的函数依赖关系中的函数依赖关系 关系SNC转换成BCNF后,数据冗余度明显降低。学生的姓名只在关系S1中存储一次,学生要改名时,只需改动一条学生记录中的相应的SN值,从而不会发生修改异常。 返回返回例例4.44.4设关系模式设关系模式TCSTCST T,C C,S S),),
38、T T表示教师,表示教师,C C表示课程,表示课程,S S表表示学生。语义假设是,每一位教师只讲授一门课程;每门课程由示学生。语义假设是,每一位教师只讲授一门课程;每门课程由多个教师讲授;某一学生选定某门课程,就对应于一确定的教师。多个教师讲授;某一学生选定某门课程,就对应于一确定的教师。根据语义假设,根据语义假设,TCSTCS的函数依赖是:的函数依赖是:(S S,C C)TT,(,(S S,T T)CC,TCTC。函数依赖图如图函数依赖图如图4.134.13所示。所示。 SCTSTC4.13 TCS4.13 TCS中的函数依赖关系中的函数依赖关系 返回返回对于对于TCSTCS,(,(S S,
39、C C和和S S,T T都是候选键,两个候选键相交,有都是候选键,两个候选键相交,有公共的属性公共的属性S S。TCSTCS中不存在非主属性,也就不可能存在非主属性对中不存在非主属性,也就不可能存在非主属性对键的部分依赖或传递依赖,所以键的部分依赖或传递依赖,所以TCSTCS3NF3NF。但从但从TCSTCS的一个关系实例如图的一个关系实例如图4.144.14分析,仍存在一些问题。分析,仍存在一些问题。 TCST1C1S1T1C1S2T2C1S3T2C1S4T3C2S2T4C2S2T4C3S2图图4.14 4.14 关系关系TCS TCS 返回返回1 1数据冗余。虽然每个教师只开一门课,但每个
40、选修该数据冗余。虽然每个教师只开一门课,但每个选修该教师该该门课程的学生元组都要记录这一信息。教师该该门课程的学生元组都要记录这一信息。2 2插入异常。当某门课程本学期不开,自然就没有学生插入异常。当某门课程本学期不开,自然就没有学生选修。没有学生选修,因为主属性不能为空,教师上选修。没有学生选修,因为主属性不能为空,教师上该门课程的信息就无法插入。同样原因,学生刚入校该门课程的信息就无法插入。同样原因,学生刚入校, ,尚未选课,有关信息也不能输入。尚未选课,有关信息也不能输入。3 3删除异常。如果选修某门课程的学生全部毕业,删除删除异常。如果选修某门课程的学生全部毕业,删除学生记录的同时学生记录的同时, ,随之也删除了教师开设该门课程的信随之也删除了教师开设该门课程的信息。息。4 4更新异常。当某个教师开设的某门课程改名后,所有更新异常。当某个教师开设的某门课程改名后,所有选修
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 湖北孝感美珈职业学院《组织行为学》2023-2024学年第二学期期末试卷
- 昆明艺术职业学院《中外美术史》2023-2024学年第二学期期末试卷
- 四川文化艺术学院《轨道交通自动化专题》2023-2024学年第二学期期末试卷
- 2025届湖南省高考历史仿真模拟试卷02
- 2025年上海市安全员《C证》考试题库
- 晋中学院《特种铸造》2023-2024学年第二学期期末试卷
- 林州建筑职业技术学院《商业插图》2023-2024学年第二学期期末试卷
- 黑龙江中医药大学《商务沟通与谈判》2023-2024学年第二学期期末试卷
- 拉萨师范高等专科学校《大数据安全技术》2023-2024学年第二学期期末试卷
- 长沙学院《生物药物检测技术与设备》2023-2024学年第二学期期末试卷
- 转运铁水包安全风险告知卡
- 31863:2015企业履约能力达标全套管理制度
- 苏教版数学二年级下册《认识时分》教案(无锡公开课)
- 打造金融级智能中台的数据底座
- 工程合同管理教材(共202页).ppt
- ANKYLOS机械并发症处理方法
- 道路桥梁实习日记12篇
- 第十章运动代偿
- 氩弧焊机保养记录表
- 明星97iii程序说明书
- 《企业经营统计学》课程教学大纲
评论
0/150
提交评论