函数依赖闭包

标签:
函数依赖闭包函数依赖闭包属性集上岸的鱼 |
分类: 教育教学资源 |
函数依赖闭包
一、函数依赖的逻辑蕴涵
定义:设有关系模式R(U)及其函数依赖集F,如果对于R的任一个满足F的关系r函数依赖X→Y都成立,则称F逻辑蕴涵X→Y,或称X→Y可以由F推出。
例:关系模式 R=(A,B,C),函数依赖集F={A→B,B→C}, F逻辑蕴涵A→C。
证:设u,v为r中任意两个元组:
满足F依赖集的所有元组都函数依赖X→Y(X→Y不属于F集),则称F逻辑蕴涵X→Y
(X→Y由F依赖集中所有依赖关系推断而出)
二、Armstrong公理
推理规则F1、F2、F3合称Armstrong公理;
F4 ∽ F7可由F1、F2、F3推得,是Armstrong公理的推论部分。
定义:若F为关系模式R(U)的函数依赖集,我们把F以及所有被F逻辑蕴涵的函数依赖的集合称为F的闭包,记为F+。
即:F+={X→Y|X→Y∈F∨“应用Armstong公理从F中导出的任何X→Y”}
http://xxgcxy.hutc.zj.cn/sjkyl/image/tball.gif
输入:有限的属性集合U、它上面的函数依赖集合F和U的一个子集X。
输出:X关于F的闭包X+。
计算方法和计算步骤:
⑴设置初始值:令X(0)=空集,X(1)=X,F'=空集;
⑵如果X(0)≠X(1),令X(0)=X(1),否则转⑷;
⑶构造函数依赖集F'={Y->Z |
(Y->Z)属于F且Y?X(1)},令 F=F-F'
对F'中的每一个函数依赖Y->Z,令X(1)= X(1)∪Z,转⑵
⑷ 输出X(1),它就是X+。
例4.10
设有关系模式R(A,B,C,D,E),其属性集上函数依赖:F={AB->C,
B->D, C->E, EC->B,
AC->B},这里的AB->C是{A,
B}->{C}的简写。
令X={A, B},求X+。
解: 计算过程是根据循环次数介绍的。由算法4.1
第一次:⑴ X(0)=空集,X(1)={A, B},F'=空集;
⑵ 由于X(0)≠X(1),令X(0)=X(1)={A, B};
⑶ 函数依赖集F'={ AB->C,
B->D},令F=F-F'={C->E,
EC->B, AC->B},
将F'中的每一个函数依赖的右端属性C,D并入X(1)中,
即令X(1)={A, B}∪{C, D}={A, B, C, D};
第二次:⑵ 由于X(0)?X(1),令X(0)=X(1)= {A, B, C, D};
将F'中的每一个函数依赖的右端属性E, B并入X(1)中,
即令X(1)={A, B, C, D }∪{E, B}={A, B, C, D, E} ;
第三次:⑵ 由于X(0)≠X(1),令X(0)=X(1)= {A, B, C, D, E } ;
将F'中的每一个函数依赖的右端属性B并入X(1)中,
即令X(1)={A, B, C, D, E }∪{B}={A, B, C, D, E};
第四次:⑵ 由于X(0)=X(1),转⑷
四、属性集闭包
1、定义:若F为关系模式R(U)的函数依赖集,X是U的子集,则由Armstrong公理推导出的所有X→Ai所形成的属性集
例:设R=ABC,F={A→B, B→C}当X分别为A,B,C是求X+。
解:当X=A时,X+=ABC
* X代表的属性集可以决定的属性集(包括本身)
2、定理:当且仅当Y属于X+时,X→Y能根据Armstron公理由F导出。
证:设Y=A1,A2,…,An
3、计算X+
(1)算法依据:若F为关系模式R(U)的函数依赖集,X,Z,W是U的子集,对于任意的Z→W∈F,若 X≥Z(表X包含Z),则X→XW。
(2)算法:
a.令X+ = X;
b.在F中依次查找每个没有被标记的函数依赖,若“左边属性集”包含于X+ ,则令 X+ =
X+∪“右边属性集”,为被访问过的函数依赖设置访问标记。
c.反复执行b直到X+不改变为止。
(先令X+等于本身,然后在F+中依次查找左边包含于X+的属性,把其右边的对应属性并到X中)
(3)算法实现
算法伪语言描述:
例:已知关系模式R中
U={A,B,C,D, E, G},
F={AB→C, C→A, BC→D, ACD→B, D→EG, BE→C, CG→BD, CE→AG},
求(BD)+,判断BD→AC是否属于F+
解:X+=BDEGCA
结论:(BD)+=ABCDEG,BD→AC可由F导出,即BD→AC属于F+
例:已知关系模式R中
U={A,B,C,E, H, P, G},
F={AC→PE, PG→A, B→CE, A→P, GA→B,GC→A, PAB→G, AE→GB, ABCP→H},
证明BG→HE属于F+
证:因为,(BG)+
=ABCEHPG,
所以BG→HE可由F导出,即BG→HE属于F+
4、结论
判定函数依赖X→Y是否能由F导出的问题,可转化为求X+并判定Y是否是X+子集的问题。
即求闭包问题可转化为求属性集问题。
判定给定函数依赖X→Y是否蕴涵于函数依赖集F算法实现:
输入:函数依赖集合F,函数依赖X→Y
输出:若X→Y∈F+输出真,否则输出假
算法伪语言描述:
number(F,X→Y)
{ if (Y包含于close(X,F))
}
{Ai|i=1,2,…}称为X对于F的闭包,记为X+。