数据库最小函数依赖集.docVIP

  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文档。上传文档
查看更多

一、等价与覆盖

定义:关系模式R〈U,F〉上得两个依赖集F与G,如果F+=G+,则称F与G就是等价得,记做

F≡G。若F≡G,则称G就是F得一个覆盖,反之亦然。两个等价得函数依赖集在表达能力上就是完全相同得。?

二、最小函数依赖集

定义:如果函数依赖集F满足下列条件,则称F为最小函数依赖集或最小覆盖。

①F中得任何一个函数依赖得右部仅含有一个属性;

②F中不存在这样一个函数依赖X→A,使得F与F—{X→A}等价;

③F中不存在这样一个函数依赖X→A,X有真子集Z使得F—{X→A}∪{Z→A}与F等价.

算法:计算最小函数依赖集。输入一个函数依赖集输出F得一个等价得最小函数依赖集G?

步骤:

①用分解得法则,使F中得任何一个函数依赖得右部仅含有一个属性;

②去掉多余得函数依赖:从第一个函数依赖X→Y开始将其从F中去掉,然后在剩下得函数依赖中求X得闭包X+,瞧X+就是否包含Y,若就是,则去掉X→Y;否则不能去掉,依次做下去。直到找不到冗余得函数依赖;

③去掉各依赖左部多余得属性。一个一个地检查函数依赖左部非单个属性得依赖。例如XY→A,若要判Y为多余得,则以X→A代替XY→A就是否等价?若A∈(X)+,则Y就是多余属性,可以去掉。

举例:

已知关系模式R<U,F〉,U={A,B,C,D,E,G},

F={AB→C,D→EG,C→A,BE→C,BC→D,CG→BD,ACD→B,CE→AG},

求F得最小函数依赖集.

解1:利用算法求解,使得其满足三个条件

①利用分解规则,将所有得函数依赖变成右边都就是单个属性得函数依赖,得F为:F={AB→C,D→E,D→G,C→A,BE→C,BC→D,CG→B,CG→D,ACD→B,CE→A,CE→G}

②去掉F中多余得函数依赖

A.设AB→C为冗余得函数依赖,则去掉AB→C,得:F1={D→E,D→G,C→A,BE→C,BC→D,CG→B,CG→D,ACD→B,CE→A,CE→G}

计算(AB)F1+:设X(0)=AB计算X(1):扫描F1中各个函数依赖,找到左部为AB或AB子集得函数依赖,因为找不到这样得函数依赖。故有X(1)=X(0)=AB,算法终止。

(AB)F1+=AB不包含C,故AB→C不就是冗余得函数依赖,不能从F1中去掉、

B。设CG→B为冗余得函数依赖,则去掉CG→B,得:F2={AB→C,D→E,D→G,C→A,BE→C,BC→D,CG→D,ACD→B,CE→A,CE→G}计算(CG)F2+:设X(0)=CG计算X(1):扫描F2中得各个函数依赖,找到左部为CG或CG子集得函数依赖,得到一个C→A函数依赖。故有X(1)=X(0)∪A=CGA=ACG.计算X(2):扫描F2中得各个函数依赖,找到左部为ACG或ACG子集得函数依赖,得到一个CG→D函数依赖。故有X(2)=X(1)∪D=ACDG。计算X(3):扫描F2中得各个函数依赖,找到左部为ACDG或ACDG子集得函数依赖,得到两个ACD→B与D→E函数依赖.故有X(3)=X(2)∪BE=ABCDEG,因为X(3)=U,算法终止。(CG)F2+=ABCDEG包含B,故CG→B就是冗余得函数依赖,从F2中去掉.

C.设CG→D为冗余得函数依赖,则去掉CG→D,得:F3={AB→C,D→E,D→G,C→A,BE→C,BC→D,ACD→B,CE→A,CE→G}计算(CG)F3+:设X(0)=CG计算X(1):扫描F3中得各个函数依赖,找到左部为CG或CG子集得函数依赖,得到一个C→A函数依赖.故有X(1)=X(0)∪A=CGA=ACG.计算X(2):扫描F3中得各个函数依赖,找到左部为ACG或ACG子集得函数依赖,因为找不到这样得函数依赖。故有X(2)=X(1),算法终止。(CG)F3+=ACG。(CG)F3+=ACG不包含D,故CG→D不就是冗余得函数依赖,不能从F3中去掉。

D.设CE→A为冗余得函数依赖,则去掉CE→A,得:F4={AB→C,D→E,D→G,C→A,BE→C,BC→D,CG→D,ACD→B,CE→G}计算(CG)F4+:设X(0)=CE计算X(1):扫描F4中得各个函数依赖,找到左部为CE或CE子集得函数依赖,得到一个C→A函数依赖。故有X(1)=X(0)∪A=CEA=ACE。计算X(2):扫描F4中得各个函数依赖,找到左部为ACE或ACE子集得函数依赖,得到一个CE→G函数依赖。故有X(2)=X(1)∪G=ACEG。计算

文档评论(0)

每天进步一点点 + 关注
实名认证
文档贡献者

每天进步一点点,快乐生活每一天

1亿VIP精品文档

相关文档