数据库范式(wiki)

数据库范式

第一范式: 1NF
wiki: 第一正规化(1NF)是资料库正规化所使用的正规形式。第一正规化是为了要排除 重复群 的出现,所采用的方法是要求资料库的每个列的值域都是由原子值组成;每个栏位的值都只能是单一值。1971年埃德加·科德提出了第一正规化。
要点:原子性
反例:重复组,缺乏唯一标识 (如1个字段存储多个值,或1个值分成多个字段存储)
正例:表字段拆分

 

第二范式: 2NF
wiki: 第二范式(2NF)是数据库正规化所使用的正规形式。规则是要求数据表里的所有数据都要和该数据表的键(主键与候选键)有完全依赖关系:每个非键属性必须独立于任意一个候选键的任意一部分属性。如果有哪些数据只和一个键的一部分有关的话,就得把它们独立出来变成另一个数据表。如果一个数据表的键只有单个字段的话,它就一定符合第二范式。
要点:唯一性
正例:数据和键完全依赖(主键唯一,通过键可以唯一定位到某条数据)

 

第三范式:3NF
wiki: 第三范式(3NF)是数据库正规化所使用的正规形式,要求所有非主键属性都只和候选键有相关性,也就是说非主键属性之间应该是独立无关的。
如果再对第三范式做进一步加强就成了BC范式,强调的重点在于“数据间的关系是奠基在主键上、以整个主键为考量、而且除了主键之外不考虑其他因素”。
要点:冗余性
正例:非主键属性之间应该是独立无关,且无需添加多余无用列
反例:存在‘单价’‘数量’,无需再添加‘合计’列

 

BC范式:BCNF
wiki: Boyce-Codd范式(英语:Boyce-Codd normal form,缩写BCNF),是数据库规范化的一种正规形式。是在第三范式的基础上加上稍微更严格约束,每个BCNF关系都满足第三范式。BCNF去除了属性间的不必要的函数依赖。

 

第四范式:4NF
wiki:第四正规化 是资料库正规化中所使用的一种正规形式,是BC范式之后的另一层次的规范化。第二范式、第三范式、BC范式关注于属性集合之间的函数依赖;而第四范式关注更一般形式称作多值依赖。

 

第五范式:5NF
wiki:关系数据库设计的第五范式 (5NF),也称投影-连接范式 是数据库规范化的一个级别,以去除多个关系之间的语义相关。一张表满足第五范式当且仅当它的每个连接依赖可由候选键推出。

 

DK范式:DK/NF
wiki:关系数据库设计的域键范式,是数据库规范化的一个级别,以去除关系不包含于域约束 的其他约束。

 

第六范式:6NF
wiki:关系数据库设计的第六范式 (6NF),是数据库规范化的级别,根据Christopher J. Date的基于关系代数的定义,关系算符,如连接(join)可以推广到自然处理间隔数据,如日期序列或时间间隔, 例如时间数据库。 第六范式基于这种推广的join:

 

参考:

1NF:https://zh.wikipedia.org/wiki/%E7%AC%AC%E4%B8%80%E6%AD%A3%E8%A6%8F%E5%8C%96

2NF:https://zh.wikipedia.org/wiki/%E7%AC%AC%E4%BA%8C%E6%AD%A3%E8%A6%8F%E5%8C%96

3NF:https://zh.wikipedia.org/wiki/%E7%AC%AC%E4%B8%89%E6%AD%A3%E8%A6%8F%E5%8C%96

BCNF:https://zh.wikipedia.org/wiki/BC%E6%AD%A3%E8%A6%8F%E5%8C%96

4NF:https://zh.wikipedia.org/wiki/%E7%AC%AC%E5%9B%9B%E6%AD%A3%E8%A6%8F%E5%8C%96

5NF:https://zh.wikipedia.org/wiki/%E7%AC%AC%E4%BA%94%E8%8C%83%E5%BC%8F

DK/NF:https://zh.wikipedia.org/wiki/%E5%9F%9F%E9%94%AE%E8%8C%83%E5%BC%8F

6NF:https://zh.wikipedia.org/wiki/%E7%AC%AC%E5%85%AD%E8%8C%83%E5%BC%8F

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值