在关系数据库中的关系是要满足一定要求的,满足不同程度要求为不同范式,越高的范式数据库冗余越小。但是有些时候一昧的追求范式减少冗余,反而会降低数据读写的效率,这个时候就要反范式,利用空间来换时间。
目前关系数据库有六种范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、巴斯-科德范式(BCNF)、第四范式(4NF)和第五范式(5NF,又称完美范式)。满足最低要求的叫第一范式(1NF)。在第一范式的基础上进一步满足更多规范要求的称为第二范式(2NF),其余范式以次类推。一般说来,数据库只需满足第三范式(3NF)就行了。
![范式关系图](https://i-blog.csdnimg.cn/blog_migrate/d0acd1190bd3745e4193c7abe71a2bd7.png)
第一范式(1NF)
即表的列具有原子性,不可再分解, 只要数据库是关系型数据库,就自动的满足1NF。
第二范式(2NF)
第二范式(2NF)要求数据库表中的每个实例或行必须可以被惟一地区分。为实现区分通常需要我们设计一个主键来实现。
第三范式(3NF)
第三范式(3NF)要求数据库表中不包含已在其它表中已包含的非主键字段。就是说,表的信息,如果能够被推导出来,就不应该单独的设计一个字段来存放。
符合3NF要求的数据库设计,基本上解决了数据冗余过大,插入异常,修改异常,删除异常的问题。当然,在实际中,往往为了性能上或者应对扩展的需要,经常只做到2NF或者1NF。