数据库关系分解为BCNF范式

数据库关系分解为BCNF范式,第1张

标准答案是:AC,BC,CD。

分析如下:R(A,B,C,D)函数依赖于AB^100c,C^D和D^A,找到违反BCNF的依赖项(不需要找到右侧多个属性的度数)并将其分解为BCNF关系的聚合。

关系:C→A,版本C→D,D→A,AB→D,AB→C,AC→D,BC→D,BC→A,BC→D,BD→A,BD→C,CD→A,ABC→D,ABD→C,权值BCD→A。

违反BCNF:C到A,C到D,D到A,AC到D,CD到A。

扩展资料:

BCNF范式在3NF的基础上消除了对主代码子集的依赖。

仓库管理关系表为例:仓库编号、存储项编号、管理员编号和数量。首先,该表满足第三种标准形式,这意味着管理员只在一个仓库中工作,而一个仓库可以存储多个项目。表中有以下依赖项:

(仓库编号、存储项目编号)——>(管理员编号、数量)

(管理员编号、存储项目编号)——>(仓库编号、数量)

从上面的依赖关系中,我们可以知道(仓库号、存储项号)和(管理员号、存储项号)是表关系中的候选代码。

表中唯一的非键字段是number,它符合第三种范式。但由于存在以下决定关系:

(仓库号)——>(管理员号)

(管理员编号)——>(仓库编号)

也就是说,有一个关键字段来确定关键字段,所以它不符合BCNF。

解决方案:将仓库管理关系表拆分成两个关系仓库管理表(仓库号、管理员号)和仓库表(仓库号、存储项号、数量)使数据库表符合BCNF,消除删除异常、插入异常和更新异常。

1、关系模式的分解准则

2、关系模式的规范化过程是通过对关系模式的分解来实现的。把低一级的关系模式分解为若干个高一级的关系模式。这种分解不是唯一的。

3、规范化的方式是进行模式分解,模式分解的原则是与原模式等价,模式分解的标准是:

4、模式分解具有无损连接性

5、模式分解能够保持函数依赖


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10659914.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-10
下一篇 2023-05-10

发表评论

登录后才能评论

评论列表(0条)

保存