数据库中将1NF分解成BCNF的过程

问题遇到的现象和发生背景

我在分解成BCNF的过程中,我把那个D->E转换成BC->E,这样算对吗

img

遇到的现象和发生背景,请写出第一个错误信息
用代码块功能插入代码,请勿粘贴截图。 不用代码块回答率下降 50%
运行结果及详细报错内容
我的解答思路和尝试过的方法,不写自己思路的,回答率下降 60%
我想要达到的结果,如果你需要快速回答,请尝试 “付费悬赏”
  1. 首先来看一下这个函数依赖图是不是只有当组合键为ABC时才能遍历完整个关系模式,所以候选码为ABC

  2. 其次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。