数据库原理:如何求一个关系模式的候选码

导读:本篇文章讲解 数据库原理:如何求一个关系模式的候选码,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

若W是候选键,则必须满足两个条件:W的闭包是U;W没有冗余。

设关系模式R中U=ABC…….等N个属性,U中的属性在FD中有四种范围:

求候选码的简单方法方法: 
(1)如果有属性不在函数依赖集中出现,那么它必须包含在候选码中;
(2)如果有属性不在函数依赖集中任何函数依赖的右边出现,那么它必须包含在候选码中;
(3)如果有属性只在函数依赖集的左边出现,则该属性一定包含在候选码中。
(4)如果有属性或属性组能唯一标识元组,则它就是候选码;

算法:按以下步骤求候选键:
1.只在FD右部出现的属性,不属于候选码;
2.只在FD左部出现的属性,一定存在于某候选码当中;
3.外部属性一定存在于任何候选码当中;
4.其他属性逐个与2,3的属性组合,求属性闭包,直至X的闭包等于U,若等于U,则X为候选码。


例1:

R<U,F>,U=(A,B,C,D,E,G),F={AB–>C,CD–>E,E–>A.A–>G},求候选码。

  1.   因G只在右边出现,所以G一定不属于候选码;而B,D只在左边出现,所以B,D一定属于候选码;BD的闭包还是BD,则对BD进行组合,除了G以外,BD可以跟A,C,E进行组合
  2.   (1)先看ABD,ABD本身自包ABD,而AB–>C,CD–>E,A–>G,所以ABD的闭包为ABDCEG=U      (2)再看BDC,CD–>E,E–>A,A–>G,BDC本身自包,所以BDC的闭包为BDCEAG=U                    (3)最后看BDE,E–>A,A–>G,AB–>C,BDE本身自包,所以BDE的闭包为BDEAGC=U
  3.   因为(ABD)、(BCD)、(BDE)的闭包都是ABCDEG所以本问题的候选码有3个分别是ABC、BCD和BDE

例2:

R<U,F>,U=(A,B,C),F={AB–>C,C–>B},求候选码。

  1. 因为A只出现在左边,所以A一定是候选键。A的闭包还是A,则对A进行组合,可以和B,C进行组合。
  2. 首先看AB,AB本身自包AB,而AB–>C,所以AB的闭包是ABC=U。                                    再看AC,AC本身自包AC,而C–>B,所以AC的闭包是ABC=U。
  3. 因为AB,AC的闭包都是ABC,也就是U,所以候选键是AB,AC。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/103034.html

(0)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!