关系数据库设计讲义.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
关系数据库设计讲义

第五章 关系数据库设计; 关系数据库设计是数据库应用开发的关键步骤。一个设计的不好的关系模式会带来数据冗余、更新复杂等问题。 所以需要对这样的关系模式进行规范化,而规范化的理论基础是建立在函数依赖和多值依赖的基础之上的。;5.1 问题的提出;;例:描述学生的数据库: 学生: 学号(Sno)、所在系(Sdept) 系主任姓名(Mname)、课程名(Cname) 成绩(Grade);;关系模式StudentU, F中存在的问题;⒊ 插入异常(Insertion Anomalies) 该插的数据插不进去 例,如果一个系刚成立,尚无学生,我们就无法把这个系及其系主任的信息存入数据库。 ⒋ 删除异常(Deletion Anomalies) 不该删除的数据不得不删 例,如果某个系的学生全部毕业了, 我们在删除该系学生信息的同时,把这个系及其系主任的信息也丢掉了。;结论: Student关系模式不是一个好的模式。 “好”的模??: 不会发生插入异常、删除异常、更新异常, 数据冗余应尽可能少。 原因:由存在于模式中的某些数据依赖引起的. 解决方法:通过分解关系模式来消除其中不合适 的数据依赖。;5.2 函数依赖的概念;1、函数依赖;“X函数决定Y” 或 “Y函数依赖于X”,记作X→Y。 ;说明: ;例: Student(Sno, Sname, Ssex, Sage, Sdept) 假设不允许重名,则有: Sno → Ssex, Sno → Sage , Sno → Sdept, Sno ←→ Sname, Sname → Ssex, Sname → Sage Sname → Sdept 但Ssex →Sage 若X→Y,并且Y→X, 则记为X←→Y。 若Y不函数依赖于X, 则记为X─→Y。;2、平凡函数依赖与非平凡函数依赖;对于任一关系模式,平凡函数依赖都是必然成立的,它不反映新的语义,因此若不特别声明, 我们总是讨论非平凡函数依赖。;3、完全函数依赖与部分函数依赖; 例: 在关系SC(Sno, Cno, Grade)中, 由于:Sno →Grade,Cno → Grade, 因此:(Sno, Cno) f Grade ;4、传递函数依赖;5、码; 包含在任何一个候选码中的属性,叫做主属性(Prime attribute).不包含在任何码中的属性称为非主属性(Nonprime attribute)或非码属性(Non-key attribute)。 最简单的情况,单个属性是码。 最极端的情况,整个属性组是码,称为全码(All-key)。;6、外部码;5.3 范式及其规范化;各种范式之间存在联系: 某一关系模式R为第n范式,可简记为R∈nNF。 ;规范化的基本思想: 规范化理论是用来改造关系模式,通过分解关系模式来逐步消除不合适的函数依赖,使模式中的属性子集达到某种程度的“分离”,让一个关系模式描述一个概念,一个实体或者实体之间的一种联系。若多于一个概念就把它“分离”出去,以解决插入异常、删除异常、更新异常和数据冗余问题。 因此,规范化的过程实际上就是概念单一化的过程,而这种范式就是“分离”程度的测试。;5.3.1 1NF;【例1】 如表5.3.1描述的是学生选课的情况。 ;表5.3 学生选课1关系 ;5.3.2 第二范式(2NF) ;2. 求关系模式的候选键的方法; 例2: 描述一个在校大学生的学习情况涉及以下一些属性: 学号(S#),姓名(SN),性别(SS), 身份证号(ID), 系别(SD), 学籍类型(SL),专业(SG),班级(SC), 课程号(CB),课程名(CN), 学期数(T), 学分(CG)和成绩(G). 其属性集合表示为 U={学号,姓名,性别,身份证号,系别,学籍类型, 专业,班级,学号,课程号,课程名,学期数,学分,成绩}。 有人给出了以下两种数据库模式: ;第一种: Ω1={R11, R12}。 其中: 关系模式R11={学号,姓名,性别,身份证号,系别,学籍类型, 专业,班级} 关系模式R12={学号,课程号,课程名,学期数,学分,成绩} 第二种: Ω2={R21, R22, R23} 其中: 关系模式R21={学号,姓名,性别,身份证号,系别,学籍类型, 专业,班级} 关系模式R22={学号,

文档评论(0)

gz2018gz + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档