码迷,mamicode.com
首页 > 数据库 > 详细

数据库设计三大范式简单总结

时间:2021-04-14 12:29:52      阅读:0      评论:0      收藏:0      [点我收藏+]

标签:传递   就是   国家   级别   运行   不可   3nf   要求   info   

1. 什么是三大范式?

数据库设计规范的三个级别。

 

2. 为什么要用三大范式?

避免数据冗余,使表结构更合理。

 

第一范式(1NF):

确保每列的原子性(就是每个字段都不可在拆分的最小单元),当然拆分也要有度。

比如下面 把地址拆分出了国家和城市,这就满足了第一范式

技术图片

思考:地址包含省、市、县、地区是否需要拆分?

如果仅仅起地址的作用,不需要统计,可以不拆分;如果有按地区统计的功能则需要拆分。根据自身项目需求决定。

 

第二范式(2NF):

非键字段必须依赖于键字段(在满足第一范式的前提下,要求每个表只描述一件事情)。

比如下面 订单编号跟订单日期有关系,产品编号和价格有关系,所以写在一起不合理。

技术图片

如果感觉上图比较难理解,那就看下面的图:

技术图片

 

第三范式(3NF):

消除传递依赖(在满足第二范式的前提下,除了主键以外的其他列消除传递依赖)

比如下面 既然有了顾客编号了,那顾客姓名显然就有点冗余(因为完全可以根据顾客编号得到顾客姓名)

技术图片

 如果感觉上图比较难理解,那就看下面的图:

 语文和数学确定了,总分就确定了,所以不满足第三范式

技术图片

 

为什么有时候要反三范式?

范式越高,数据冗余越少,但是效率有时就越地下,为了提高运行效率,可以适当让数据冗余。

就如上图学生总分这个表,明明没有满足第三范式,那他就是这么设计的为什么?

答:因为如果当查询这个总分数访问量比较大时,这时候就是性能更重要。当性能和规范化冲突的时候,我们首选性能。这就是“反三范式”。

 

总结:

1、第一范式约束的所有字段

2、第二范式约束的主键和非主键的关系

3、第三范式约束的非主键之间的关系

4、范式越高,冗余越少,但表也越多。

5、规范化和性能的关系 :性能比规范化更重要

 

数据库设计三大范式简单总结

标签:传递   就是   国家   级别   运行   不可   3nf   要求   info   

原文地址:https://www.cnblogs.com/dazahui/p/14655824.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!