




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、第七 章 关系数据库的设计理论,7.1 模式规范化问题的提出 7.2 函数依赖 7.3 范式和规范化 7.4 关系模式的分解,7.1 模式规范化问题的提出,关系数据库逻辑设计 针对具体问题,如何构造一个适合于它的数据模式 数据库逻辑设计的工具关系数据库的规范化理论 【例】描述学生的数据: 学号(Sno)、姓名(Sname)、年龄(Sage)、院系(Sdept)、系主任姓名(Dname)、课程名(Cname)、成绩(Grade) 学生数据库的语义: 1)一个系有若干学生,一个学生只属于一个系 2)一个系只有一名主任 3)一个学生可选修多门课程, 每门课程可有若干学生 4)每个学生所学的每门课程都
2、有一个成绩,关系模式Student(Sno,Sname,Sage,Sdept, Dname,Cname,Grade)存在如下问题,1)数据冗余 一个系有若干学生,每个学生的信息中都会有所在系和系主任的名字,系主任被反复存储 2)不一致性 由于系主任存储冗余,当某个系更新系主任时,可能只修改了一部分,而另一部分没有修改,造成存储数据的不一致 3)插入异常 如果某个系还没有招收学生,那么就无法填写系主任 4)删除异常 要删除一个学生的所有成绩,则把该学生的姓名、年龄等基本信息也都删除,结论: Student关系模式不是一个好的模式 “好”的模式不会发生插入异常、删除异常、更新异常,数据冗余应尽可能
3、少 原因: 由存在于模式中的某些数据依赖引起的 数据依赖是现实世界事物之间相互关联性的一种表达 解决方法: 通过分解关系模式消除其中不合适的数据依赖,模式问题的解决办法,若将关系分解为以下3个关系: SSno,Sname,Sage、DDept, Dname、SCSno,Cname,Grade 则可以解决所有的异常 数据冗余:一个系的系主任只在D中出现,S中只有每个学生的基本信息和所在的系,避免了系主任的冗余 数据不一致:由于不存在数据冗余,也就不存在部分修改,即不一致 插入异常:由于系主任插入在D表中,只要有系名即可,避免了没有学生就不能写系主任 删除异常:删除成绩只会删除SC表的数据,而S表
4、中的信息被保留,7.2 函数依赖,7.2.1 函数依赖的定义 7.2.2 平凡函数依赖与非平凡函数依赖 7.2.3 完全函数依赖与部分函数依赖 7.2.4 传递函数依赖,7.2.1 函数依赖的定义,【定义】 设R(U)是一个属性集U上的关系模式,X和Y是U的子集。 若对于R(U)的任意一个可能的关系r,r中不可能存在两个元组在X上的属性值相等, 而在Y上的属性值不等, 则称 “X函数确定Y” 或 “Y函数依赖于X”,记作XY X称为这个函数依赖的决定属性集 Y=f(X) 【例】在学生关系中,学号是唯一的,也就是说,不存在学号相同,而姓名不同的学生元祖,因此有学号姓名,说明:,1)函数依赖不是指
5、关系模式R的某个或某些关系实例满足的约束条件,而是指R的所有关系实例均要满足的约束条件 2)函数依赖是语义范畴的概念。只能根据数据的语义来确定函数依赖 例如“姓名年龄”这个函数依赖只有在不允许有同名人的条件下成立 3)数据库设计者可以对现实世界作强制的规定 例如规定不允许同名人出现,函数依赖“姓名年龄”成立 所插入的元组必须满足规定的函数依赖,若发现有同名人存在, 则拒绝装入该元组,Student(Sno,Sname,Sage,Sdept, Dname, Cname,Grade)中的函数依赖,若Student中允许重名,则: Sno Sname、Sno Sage、Sno Sdept、Sdept
6、 Dname、(Sno,Cname) Grade 若Student中不允许重名,则增加: Sname Sno,Sname Sage、Sname Sdept、 (Sname,Cname) Grade 注:若XY,并且YX, 则记为XY 如SnoSname 若Y不函数依赖于X,则记为: X Y 例如Sage Sdept,7.2.2 平凡函数依赖与非平凡函数依赖,【定义】关系模式R(U)中,对于U的子集X和Y 如果XY,但Y X,则称XY是非平凡的函数依赖 若XY,但Y X, 则称XY是平凡的函数依赖 例:在关系SC(Sno, Cno, Grade)中, 非平凡函数依赖: (Sno, Cno) Gr
7、ade 平凡函数依赖: (Sno, Cno) Sno、 (Sno, Cno) Cno 任一关系模式,平凡函数依赖都必然成立,它不反映新的语义,因此若不特别声明, 我们总是讨论非平凡函数依赖,4.2.3 完全函数依赖与部分函数依赖,【定义】关系模式R(U)中,对于U的子集X和Y 如果XY,并且对于X的任何一个真子集X,都有X Y, 则称Y完全函数依赖于X,记作X Y 若XY,但Y不完全函数依赖于X,则称Y部分函数依赖于X,记作X Y 【例】在关系SC(Sno, Cname, Grade)中, 由于:Sno Grade,Cname Grade, 因此:(Sno, Cname) Grade,f,P,
8、f,7.2.4 传递函数依赖,【定义】在关系模式R(U)中 如果XY,YZ,且Y X,Y X,则称Z传递函数依赖于X,记为:X Y 注: 如果YX, 即XY,则Z直接依赖于X 【例】在关系S(Sno,Sdept,Dname)中,有: Sno Sdept,Sdept Dname Dname传递函数依赖于Sno,t,7.3 范式和规范化,范式是符合某一种级别的关系模式的集合 关系数据库中的关系必须满足一定的要求。满足不同程度要求的为不同范式 范式的种类: 第一范式(1NF) 第二范式(2NF) 第三范式(3NF) BC范式(BCNF) 第四范式(4NF) 第五范式(5NF),1. 第一范式(1NF
9、),【定义】如果一个关系模式R的所有属性都是不可分的基本数据项,则R1NF 第一范式是对关系模式的最起码的要求。不满足第一范式的数据库模式不能称为关系数据库 但是满足第一范式的关系模式并不一定是一个好的关系模式,【例】 关系模式SLC(Sno, Sdept, Sloc, Cno, Grade),Sloc为学生住处,假设每个系的学生住在同一个地方 函数依赖包括:SnoSdept、SnoSloc、 SdeptSloc、(Sno, Cno) Grade、 (Sno, Cno) Sdept、 (Sno, Cno) Sloc SLC的码为(Sno, Cno),SLC满足第一范式 非主属性Sdept和Sl
10、oc部分函数依赖于码(Sno, Cno),f,P,P,06:39:34,15,SLC不是一个好的关系模式,(1) 插入异常: 假设Sno95102,SdeptIS,SlocN的学生还未选课,因课程号是主属性,因此该学生的信息无法插入SLC (2) 删除异常: 假定某个学生本来只选修了3号课程这一门课。现在因身体不适,不再选修3号课程。因课程号是主属性,此操作将导致该学生信息的整个元组都要删除 (3) 数据冗余度大: 如果一个学生选修了10门课程,那么他的Sdept和Sloc值就要重复存储了10次 (4) 修改复杂: 例如学生转系,在修改此学生元组的Sdept值的同时,还可能需要修改住处(Slo
11、c)。如果这个学生选修了K门课,则必须无遗漏地修改K个元组中全部Sdept、Sloc信息,06:39:34,16,【定义】若关系模式R1NF,并且每一个非主属性都完全函数依赖于R的码,则R2NF 【例】SLC关系模式中,Sdept、Sloc部分函数依赖于码 解决方法:SLC分解为两个关系模式,以消除这些部分函数依赖:SC(Sno, Cno, Grade)、SL(Sno, Sdept, Sloc) 函数依赖图:,2. 第二范式(2NF),采用投影分解法将一个1NF的关系分解为多个2NF的关系,可以在一定程度上减轻原1NF关系中存在的插入异常、删除异常、数据冗余度大、修改复杂等问题 将一个1NF关
12、系分解为多个2NF的关系,并不能完全消除关系模式中的各种异常情况和数据冗余 【例】2NF关系模式SL(Sno,Sdept,Sloc)中,函数依赖SnoSdept、SdeptSloc、SnoSloc,则Sloc传递函数依赖于Sno,即SL中存在非主属性对码的传递函数依赖,06:39:34,17,3 .第三范式(3NF),【定义】关系模式R中若不存在这样的码X、属性组Y及非主属性Z(Z Y),使得XY,YX,YZ,成立,则称R 3NF R是2NF,并且每一个非主属性都非传递函数依赖于主码 R是1NF,并且每一个非主属性既不部分函数依赖于主码也不传递函数依赖于主码 【例】SL(Sno, Sdept,
13、 Sloc) 2NF,但SL(Sno,Sdept,Sloc)3NF,可分解为2个模式 SD(Sno, Sdept) 3NF DL(Sdept, Sloc) 3NF,06:39:34,18,4. BC范式(BCNF),【定义】若关系模式R中的所有非平凡、完全的函数依赖的决定因素是码。则R属于BCNF R中所有非主属性对每一个码都是完全函数依赖 R中所有主属性对于每一个不包含它的码也是完全函数依赖 R中没有任何属性完全函数依赖于非码的任何一组属性 则R中不存在任何属性对码的传递依赖和部分依赖,所以R属于3NF,【例】在关系模式STJ(S,T,J)中,S表示学生,T表示教师,J表示课程 每一教师只教
14、一门课,每门课由若干教师教。某一学生选定某门课,就确定了一个固定的教师。某个学生选修某个教师的课就确定了所选课的名称 : (S,J)T,(S,T)J,TJ,分析(S,J)T,(S,T)J,TJ : STJ3NF (S,J)和(S,T)都可以作为候选码 S、T、J都是主属性 STJBCNF TJ,但T不是候选码 T是决定属性集 解决方法:将STJ分解为二个关系模式: SJ(S,J) BCNF, TJ(T,J) BCNF 没有任何属性对码的部分函数依赖和传递函数依赖,7.4 关系模式的分解,规范化程度可以有多个不同的级别 规范化程度过低的关系不一定能够很好地描述现实世界,可能会存在插入异常、删除异
15、常、修改复杂、数据冗余等问题 一个低一级范式的关系模式,通过模式分解可以转换为若干个高一级范式的关系模式集合,这种过程就叫关系模式的规范化 三种模式分解的等价定义 分解具有无损连接性(保证不丢失信息) 分解要保持函数依赖(减轻或解决各种异常情况) 分解既要保持函数依赖,又要具有无损连接性,最小依赖集,如果函数依赖集F满足下列条件,则称F为一个极小函数依赖集(最小依赖集或最小覆盖) (1) F中任一函数依赖的右部仅含有一个属性 (2) F中不存在这样的函数依赖XA,使得F与F-XA等价 (3) F中不存在这样的函数依赖XA, X有真子集Z使得F-XAZA与F等价,关系模式S(U,F)中,U=Sno,Sdept,SdeptAdmin,Cname,G F=
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024河南省建筑安装技工学校工作人员招聘考试及答案
- 股权回购合同范本
- 网络安全评估与防护合同
- 商品混凝土配送合同范本
- 电力采购合同范本
- 男生皮肤管理对比
- 国际物流模拟考试题与答案
- 现编现代企业管理
- 自制平板车应用管理
- 肠造口特色护理
- 幼儿园优质公开课:小班综合《小鸡过生日》课件
- 《新媒体推广》项目二图文推广-课前自学
- 挂篮检查验收记录表
- (完整版)好撒玛利亚人
- PCB的DFM评审报告模板
- 护理培训学习记录表
- CNAS-CL01:2018《检测和校准实验室能力认可准则》
- 中国移动公司物业管理方案
- 团结就是力量(曲谱和歌词)
- 学士成都地铁牵引变电所设计论文
- 特种设备起重机械设备(行车)专项检查细则表
评论
0/150
提交评论