原文网址:数据库--三大范式--介绍/使用/实例_IT利刃出鞘的博客-CSDN博客
简介
本文用示例来介绍数据库的三大范式。
范式介绍
范式(Normal Form):关系型数据库的规范。
设计良好结构的数据库,可以有效减小数据冗余,减少增删改中出现的问题。深入理解数据库设计的三范式,对于设计“健壮的数据库“十分有必要。数据库三范式是设计数据库时参考的准则。
目前关系数据库有六种范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、巴斯-科德范式(BCNF)、第四范式(4NF)和第五范式(5NF,又称完美范式)。满足最低要求的范式是第一范式(1NF)。在第一范式的基础上进一步满足更多规范要求的称为第二范式(2NF),其余范式以次类推。一般来说,数据库只需满足第三范式(3NF)就行了。
三大范式只是一般设计数据库的基本理念,可以建立冗余较小、结构合理的数据库。如果有特殊情况,当然要特殊对待,数据库设计最重要的是看需求跟性能,需求 > 性能 > 表结构。所以不能一味的去追求按照范式来建表。
范式 | 含义 | 详细描述 |
第一范式(1NF) | 列的原子性(无重复的列) | 每一列都是不可分割的原子数据项,是无重复的域,且不要产生冗余。 |
第二范式(2NF) | 实体的属性完全依赖于主关键字 | 表中的所有列,每一行的数据只能与其中一列相关,即一行数据只做一件事。只要数据列中出现数据重复,就要把表拆分开来。 |
第三范式(3NF) | 任何非主属性不依赖于其它非主属性 | 表中的每一列都要与主键直接相关,而不是间接相关(表中的每一列只能依赖于主键),数据不能存在传递关系。 像:a-->b-->c 属性之间含有这样的关系,是不符合第三范式的。 |
第二范式与第三范式的本质区别:在于有没有分出两张表。
第二范式是说一张表中包含了多种不同实体的属性,那么必须要分成多张表,第三范式是要求已经分好了多张表的话,一张表中只能有另一张标的ID,而不能有其他任何信息,(其他任何信息,一律用主键在另一张表中查询)。
示例
第一范式
例1 每一列都要不可分割
需求:已知省和市,按其分类
错误结构:(地址里包含了省、市,不容易满足需求,不符合第一范式。)
正确结构:(省、市、地址 分开)
上边只是部分内容,为便于维护,本文已迁移到此地址:数据库-三大范式-介绍/使用/实例 - 自学精灵