范式1NF、2NF、3NF和BCNF的区别

本文深入解析数据库规范化过程,从1NF到BCNF,详述每个范式的定义与实例,帮助理解如何消除数据冗余,提高数据一致性。

1NF:二维表中数据项不可再分就满足1NF条件。也就是说只要是正确的二维表都
满足这个条件。
主属性:候选码的每一个属性。
完全函数依赖:举个例子(Sno,Cno)->Grade。Sno-/>Grade,Cno-/>Grade.
部分函数依赖:举个例子(Sno,Cno)->Sno,(Sno,Cno)->Sage,明白了吗?拿第二个
说,(Sno,Cno)->Sage,但也可以Sno->Sage。非完全函数依赖就是部分函数依赖。
候选码:举个例子:工人(工号,身份证号,姓名,性别,部门),工号和身份证号
都可以唯一的标识一个元组,所以工号是候选码、身份证号也是候选码。

2NF

定义:若R∈1NF,且每一个非主属性完全函数依赖于任何一个候选码,则R∈2NF。

3NF

定义:若R∈1NF,且每一个非主属性既不部分函数依赖也不传递函数依赖于候选码。

也可以这样理解:若R∈2NF,且每一个非主属性不传递函数依赖于候选码。

BCNF

定义:若R∈3NF,且没有任何属性对码的部分函数依赖传递函数依赖

也可以这样理解:BCNF就是把1NF,2NF,3NF定义加起来之后,又加了一个条件。
在这里插入图片描述

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值