SQL的规范化.PPTVIP

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

第6章 规范化 本章主要内容 关系模型术语回顾 函数依赖 非规范化的关系 最基本的规范化关系存在的异常分析 范式1NF~BCNF 规范化的本质 1. 关系 关系模型的数据结构就是关系 。在用户看来,一个关系就是一张二维表,表中的一行表示实体的一个具体例子(实例),也可称为一个元组或一个记录。表中的一列就是实体的一个属性,也称为一个字段。 2. 候选键、主属性与非主属性 (1)候选键 候选键由一个属性名或多个属性名组成。它具有两个性质:性质1:表中任一行在候选键属性上的值是惟一的。因此,候选键的不同取值可以用来区分不同的行。性质2:不存在更小的真子集(更小的属性或属性组),其不同的取值也能用来区分不同的行。如Students关系的Sno列,就是一个候选键。因为,给定一个Sno的值,就能确定表中惟一的一行。一个表可能有多个候选键。 (2) 主属性与非主属性 候选键中出现的属性都是主属性,主属性以外的属性都是非主属性。 3.主键与实体完整性 (1) 主键:如果一个表有多个候选键,通常选择其中一个候选键作为区分行的惟一性标识符,称为主键。如果一个表只有一个候选键,那么这个候选键就作为主键。在Students表中只有一个候选键,则Sno就是该表的主键。 (2) 实体完整性: 表中任意一行的主键值不能为空值。 实体完整性依靠主键来实现。它要求主键值不能为空,也就是说主键值必须是某一确定的值。又因为主键是候选键之一,而根据候选键的定义,候选键列上的各个值都惟一,因此,主键列上的各个值也都惟一。可见,实体完整性也即主键值惟一且不能为空值。如Students表中,Sno列的每一个值惟一,且没有空值存在。 4. 外键与参照完整性 (1) 外键:若一个表R1中的一个列或列组对应另一个表R2的主键,那么该列或列组称为表R1的外键。例如,第二章图2-1中的选课表Enrollment(Sno,Cno,Grade),Sno不是Enrollment表的主键,但Sno是表Students (Sno,Sname,Ssex,Sage,Sdept)中的主键。因此,Sno是表Enrollment的外键。 (2)参照完整性:一个表的外键值可以为空值。若不为空值,则每一个外键值必须等于另一个表中主键的某个值。外键实现了表之间的参照完整性。 主键与外键提供了两个关系中元组之间联系的手段。当两个关系进行连接操作时就是因为有外键在起作用。 外键与主键的关系示例: 比如,我们需要查看每个学生的姓名、选课的课程号和成绩时,就涉及到Enrollment和Students两个关系的连接操作。 SELECT Sname,Cno,Grade FROM Students,Enrollment WHERE Students.Sno=Enrollment.Sno 5.关系模式 关系模式是关系的形式化描述。最简单的表示为: 关系名(属性名1,属性名2,…, 属性名n) 用英文表示为: R ( A1 , A2 , … , An )或R(U) 其中,R是关系名,Ai(1≤ i≤ n)表示R中的一个属性;U是所有属性的集合 例如:Students关系的关系模式表示为: Students(Sno, Sname, Ssex, Sage,Sdept) 关系模式就是一个表的表头,通常称为表的结构。 1.函数依赖 定义6.1:设一个关系模式R(U),R是关系的名称,U是关系R的所有属性的集合,X和Y为属性集U上的子集。若对于任一元组在X上的每一个值,都有Y上的一个惟一值与之对应,则称X函数决定Y,或称Y函数依赖于X,记作X?Y。X称为这个函数依赖的决定因子。 函数依赖可以简单理解为:如果知道属性X的值,就可以获得属性Y的值,那么属性X函数决定属性Y,或者说:属性Y函数依赖于属性X,记作X?Y。若X不函数决定Y,或Y不函数依赖于X,记作: 函数依赖实际上表示的是实体内部各属性之间的相互依赖关系,因此,函数依赖与属性间的联系类型有关。 1)若属性X和Y之间有“一对一”的联系,则存在X?Y、 Y ? X、 X← ?Y(表示X与Y等价) 2)若属性X和Y之间有“多对一”的联系,则存在X?Y、 Y ? X。 3)若属性X和Y之间有“多对多”的联系,则X与Y之间不存在任何函数依赖。 函数依赖 例: Student(Sno, Sname, Ssex, Sage, Sdept) {Sno → Sname ,Sno → Ssex, Sno → Sage , Sno → Sdept} 但Ssex →Sage 说明: 1. 函数依赖不是指关

文档评论(0)

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

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

1亿VIP精品文档

相关文档