问题遇到的现象和发生背景
我在分解成BCNF的过程中,我把那个D->E转换成BC->E,这样算对吗
我在分解成BCNF的过程中,我把那个D->E转换成BC->E,这样算对吗
首先来看一下这个函数依赖图是不是只有当组合键为ABC时才能遍历完整个关系模式,所以候选码为ABC
其次BC→D属于部分函数依赖,未到达第2NF但已经满足了原子性所以为1NF
变为2NF过程:R1 = (A,B,C) R2 =(B,C,D,E),F{BC→D,D→E} R2的候选码为BC 这样一来就消除了非主属性对码的部分函数依赖
变为3NF过程:变为2NF后R2存在非主属性对码的传递函数依赖(BC只能通过D来确定E),继续拆分R2 = (B,C,D),F{BC→D}优选码BC,R3=(D,E),F={D→E}候选码D。此时原来的R2已经不存在传递函数依赖了。
变为BCNF过程:R1中都是候选码所以不存在依赖关系,看R2、R3。R2中BC→D与R3中D→E的决定因素均为候选码,且候选码中不存在主属性对码的部分与传递函数依赖为BCNF。