数据库关系数据理论幻灯片.ppt
《数据库关系数据理论幻灯片.ppt》由会员分享,可在线阅读,更多相关《数据库关系数据理论幻灯片.ppt(45页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、数据库关系数据理论第1页,共45页,编辑于2022年,星期六6.1 问题的提出问题的提出一一.关系数据库逻辑设计关系数据库逻辑设计针针对对具具体体问问题题,如如何何构构造造一一个个适适合合于于它它的的数数据据模模式式数数据据库库逻逻辑辑设设计计的的工工具具关关系系数数据据库库的的规规范范化化理理论论第2页,共45页,编辑于2022年,星期六6.1 问题的提出问题的提出二。关系模式的形式化定义:二。关系模式的形式化定义:关系模式由五部分组成,即它是一个五元组:关系模式由五部分组成,即它是一个五元组:R(U,D,DOM,F)R:关系名关系名U:组成该关系的属性名集合组成该关系的属性名集合D:属性组
2、属性组U中属性所来自的域中属性所来自的域DOM:属性向域的映象集合:属性向域的映象集合F:属性间数据的依赖关系集合属性间数据的依赖关系集合第3页,共45页,编辑于2022年,星期六6.1 问题的提出问题的提出三。属性间数据的依赖关系三。属性间数据的依赖关系 数据依赖是一个关系内部属性和属性之间的一种约束关系数据依赖是一个关系内部属性和属性之间的一种约束关系.这种约这种约束关系是属性束关系是属性值值间的相互关连(主要体现于间的相互关连(主要体现于值的相等与否值的相等与否),它是,它是数据库模式设计的关键。数据库模式设计的关键。数据依赖的类型:函数依赖(数据依赖的类型:函数依赖(Functiona
3、l Dependency,记为,记为FD)多值依赖(多值依赖(Multivalued Dependency,记为,记为MVD)其他其他第4页,共45页,编辑于2022年,星期六6.1 问题的提出问题的提出四四.关系模式关系模式R(U,D,DOM,F)的简化表示:一个)的简化表示:一个三元组三元组R(U,F)。当且仅当当且仅当U上的一个关系上的一个关系r 满足满足F时,时,r称为关系模式称为关系模式 R(U,F)的一)的一个关系。个关系。五五.数据依赖对关系模式的影响数据依赖对关系模式的影响例:描述学校的数据库:例:描述学校的数据库:学生的学号(学生的学号(Sno)、所在系()、所在系(Sdep
4、t)、)、系主任姓名(系主任姓名(Mname)、)、课程号(课程号(Cno)、成绩()、成绩(Grade)第5页,共45页,编辑于2022年,星期六6.1 问题的提出假设是一个单一的关系模式:Student U Sno,Sdept,Mname,Cno,Grade 属性组U上的一组函数依赖F:F Sno Sdept,Sdept Mname,(Sno,Cno)Grade SnoCnoSdeptMnameGrade第6页,共45页,编辑于2022年,星期六6.1 问题的提出问题的提出 数据冗余太大。浪费大量的存储空间。数据冗余太大。浪费大量的存储空间。例:每一个系主任的姓名重复出现例:每一个系主任的
5、姓名重复出现 更新异常(更新异常(Update AnomaliesUpdate Anomalies)。因数据冗余)。因数据冗余 ,更新数据时,维更新数据时,维护数据完整性代价大。护数据完整性代价大。例:某系更换系主任后,系统必须修改与该系学生有关的每一个元组例:某系更换系主任后,系统必须修改与该系学生有关的每一个元组 插入异常(插入异常(Insertion AnomaliesInsertion Anomalies):该插的数据插不进去):该插的数据插不进去 删除异常(删除异常(Deletion AnomaliesDeletion Anomalies)第7页,共45页,编辑于2022年,星期六
6、6.1 问题的提出结论结论:Student关系模式不是一个好的模式。关系模式不是一个好的模式。“好好”的模式:的模式:不会发生插入异常、删除异常、更新异常,不会发生插入异常、删除异常、更新异常,数据冗余应尽可能少。数据冗余应尽可能少。原因:由存在于模式中的某些原因:由存在于模式中的某些数据依赖数据依赖引起的引起的解决方法:通过解决方法:通过分解分解关系模式来消除其中关系模式来消除其中不合适不合适 的数据依赖的数据依赖。第8页,共45页,编辑于2022年,星期六6.2 规范化规范化规范化理论规范化理论正是用来改造关系模式,通过分解关系模式来消除其中不合正是用来改造关系模式,通过分解关系模式来消除
7、其中不合适的数据依赖,以解决插入异常、删除异常、更新异常和数据冗余问题。适的数据依赖,以解决插入异常、删除异常、更新异常和数据冗余问题。函数依赖函数依赖 一、一、函数依赖函数依赖 二、二、平凡函数依赖与非平凡函数依赖平凡函数依赖与非平凡函数依赖 三、三、完全函数依赖与部分函数依赖完全函数依赖与部分函数依赖 四、四、传递函数依赖传递函数依赖第9页,共45页,编辑于2022年,星期六函数依赖函数依赖定义:设定义:设R(U)是一个属性集是一个属性集U上的关系模式,上的关系模式,X和和Y是是U的子集。的子集。若对于若对于R(U)的的任意任意一个可能的关系一个可能的关系r,r中不可能存在两个元组在中不可
8、能存在两个元组在X上的属性值相等,上的属性值相等,而在而在Y上的属性值不等,上的属性值不等,则称则称“X函数确定函数确定Y”或或 “Y函数依赖于函数依赖于X”,记作,记作XY。X称为这个函数依赖的决定属性集称为这个函数依赖的决定属性集(Determinant)。Y=f(x)说明:说明:1.函数依赖不是指关系模式函数依赖不是指关系模式R的某个或某些关系实例满足的约束条件,而的某个或某些关系实例满足的约束条件,而是指是指R的的所有关系实例所有关系实例均要满足的约束条件。均要满足的约束条件。2.函数依赖是函数依赖是语义范畴语义范畴的概念。只能根据数据的语义来确定函数依赖。的概念。只能根据数据的语义来
9、确定函数依赖。第10页,共45页,编辑于2022年,星期六函数依赖函数依赖3.数据库设计者可以对现实世界作强制的规定。例如规定不允许同名数据库设计者可以对现实世界作强制的规定。例如规定不允许同名人出现,函数依赖人出现,函数依赖“姓名姓名年龄年龄”成立。所插入的元组必须满足成立。所插入的元组必须满足规定的函数依赖,若发现有同名人存在,规定的函数依赖,若发现有同名人存在,则拒绝装入该元组。则拒绝装入该元组。例例:Student(Sno,Sname,Ssex,Sage,Sdept)假设不允许重名,则有假设不允许重名,则有:Sno Ssex,Sno Sage,Sno Sdept,SnoSname,Sn
10、ame Ssex,Sname Sage Sname Sdept,但但Ssex Sage若若XY,并且,并且YX,则记为则记为XY。若若Y不函数依赖于不函数依赖于X,则记为则记为XY。第11页,共45页,编辑于2022年,星期六二、平凡函数依赖与非平凡函数依赖二、平凡函数依赖与非平凡函数依赖在关系模式在关系模式R(U)中,对于中,对于U的子集的子集X和和Y,如果如果XY,但,但Y X,则称,则称XY是非平凡的函数依赖是非平凡的函数依赖若若XY,Y X,则称则称XY是是平凡的函数依赖平凡的函数依赖例:在关系例:在关系SC(Sno,Cno,Grade)中,中,非平凡函数依赖:非平凡函数依赖:(Sno
11、,Cno)Grade 平凡函数依赖:平凡函数依赖:(Sno,Cno)Sno (Sno,Cno)Cno 对于任一关系模式,平凡函数依赖都是必然成立的。对于任一关系模式,平凡函数依赖都是必然成立的。第12页,共45页,编辑于2022年,星期六三、完全函数依赖与部分函数依赖三、完全函数依赖与部分函数依赖定义:在关系模式定义:在关系模式R(U)中,如果中,如果XY,并且对于,并且对于X的任何的任何一个真子集一个真子集X,都有,都有 X Y,则称则称Y完全函数依赖于完全函数依赖于X,记作,记作X Y。若若XY,但,但Y不完全函数依赖于不完全函数依赖于X,则称,则称Y部分函数依赖于部分函数依赖于X,记作,
12、记作X P Y。例例:在关系在关系SC(Sno,Cno,Grade)中,中,由于:由于:Sno Grade,Cno Grade,因此:因此:(Sno,Cno)Grade第13页,共45页,编辑于2022年,星期六四、传递函数依赖四、传递函数依赖定义定义5.3 在关系模式在关系模式R(U)中,如果中,如果XY,YZ,且,且Y X,Z Y,YX,则称,则称Z传递函数依赖于传递函数依赖于X。注注:如果如果YX,即即XY,则,则Z直接依赖于直接依赖于X。例例:在关系在关系Std(Sno,Sdept,Mname)中,有:中,有:Sno Sdept,Sdept Mname Mname传递函数依赖于传递函数
13、依赖于Sno第14页,共45页,编辑于2022年,星期六码码 设设K为关系模式为关系模式R中的属性或属性组合。若中的属性或属性组合。若K U,则则K称为称为R的一个的一个侯选码侯选码(Candidate Key)。若关系模式)。若关系模式R有多个候选码,则选定其中的一个做为有多个候选码,则选定其中的一个做为主码主码(Primary key)。)。定义:关系模式定义:关系模式 R R 中属性或属性组中属性或属性组X X 并非并非 R R的码,但的码,但 X X 是另一个关系模式的码,则称是另一个关系模式的码,则称 X X 是是R R 的的外部码外部码(Foreign Foreign keykey
14、)也称外码。)也称外码。主码又和外部码一起提供了表示关系间联系的手段。主码又和外部码一起提供了表示关系间联系的手段。第15页,共45页,编辑于2022年,星期六6.3 范式l范式是符合某一种级别的关系模式的集合。范式是符合某一种级别的关系模式的集合。l关系数据库中的关系必须满足一定的要求。满足不同程度要求的为不同范式。关系数据库中的关系必须满足一定的要求。满足不同程度要求的为不同范式。l范式的种类:范式的种类:第一范式第一范式(1NF)第二范式第二范式(2NF)第三范式第三范式(3NF)BC范式范式(BCNF)第四范式第四范式(4NF)第五范式第五范式(5NF)l各种范式之间存在联系:各种范式
15、之间存在联系:l 某一关系模式某一关系模式R为第为第n范式,可简记为范式,可简记为RnNF第16页,共45页,编辑于2022年,星期六l第一范式(第一范式(1NF)如果一个关系模式如果一个关系模式R R的所有属性都是不可分的基本数据项,则的所有属性都是不可分的基本数据项,则R1NFR1NF。第一范式是对关系模式的最起码的要求。不满足第一范式的数据第一范式是对关系模式的最起码的要求。不满足第一范式的数据库模式不能称为关系数据库。库模式不能称为关系数据库。但是满足第一范式的关系模式并不一定是一个好的关系模但是满足第一范式的关系模式并不一定是一个好的关系模式。式。第17页,共45页,编辑于2022年
16、,星期六例例:关系模式关系模式 SLC(Sno,Sdept,Sloc,Cno,Grade)Sloc为学生住处,假设每个系的学生住在同一个地方。为学生住处,假设每个系的学生住在同一个地方。SLC的码为(Sno,Cno),满足1NF,非主属性Sdept和Sloc部分函数依赖于码(Sno,Cno)函数依赖包括:函数依赖包括:(Sno,Cno)f Grade Sno Sdept (Sno,Cno)P Sdept Sno Sloc (Sno,Cno)P Sloc Sdept SlocSnoCnoGradeSdeptSlocSLC第18页,共45页,编辑于2022年,星期六(1)插入异常插入异常没选课的学
17、生记录无法插入。没选课的学生记录无法插入。(2)删除异常删除异常 假定某个学生本来只选修了一门课。现在一门都不选修了。假定某个学生本来只选修了一门课。现在一门都不选修了。因课程号是主属性,此操作将导致该学生信息的整个元组都要因课程号是主属性,此操作将导致该学生信息的整个元组都要删除。删除。(3)数据冗余度数据冗余度(4)修改复杂修改复杂l原因原因 Sdept、Sloc两个非主属性部分函数依赖于码。两个非主属性部分函数依赖于码。l解决方法解决方法 SLC分解为两个关系模式,以消除这些部分函数依赖分解为两个关系模式,以消除这些部分函数依赖 SC(Sno,Cno,Grade)SL(Sno,Sdept
18、,Sloc)第19页,共45页,编辑于2022年,星期六SnoCnoGradeSCSLSnoSdeptSlocl第二范式(第二范式(2NF)定义:若关系模式定义:若关系模式R1NF,并且每一个,并且每一个非主非主属性都属性都完全完全函数依赖于函数依赖于R的码,则的码,则R2NF。例:例:SLC(Sno,Sdept,Sloc,Cno,Grade)1NF SLC(Sno,Sdept,Sloc,Cno,Grade)2NF SC(Sno,Cno,Grade)2NF SL(Sno,Sdept,Sloc)2NF第20页,共45页,编辑于2022年,星期六l码只包含一个属性的关系模式若属于码只包含一个属性的
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据库 关系 数据 理论 幻灯片
限制150内