数据库设计三大范式

本贴最后更新于 1863 天前,其中的信息可能已经时异事殊

范式是什么

规范的的数据库是需要满足一些规范的来优化数据数据存储方式。在关系型数据库中这些规范就可以称为范式。

什么是三大范式:

第一范式:当关系模式 R 的所有属性都不能在分解为更基本的数据单位时,称 R 是满足第一范式的,简记为 1NF。满足第一范式是关系模式规范化的最低要求,否则,将有很多基本操作在这样的关系模式中实现不了。

第二范式:如果关系模式 R 满足第一范式,并且 R 得所有非主属性都完全依赖于 R 的每一个候选关键属性,称 R 满足第二范式,简记为 2NF。

第三范式:设 R 是一个满足第一范式条件的关系模式,X 是 R 的任意属性集,如果 X 非传递依赖于 R 的任意一个候选关键字,称 R 满足第三范式,简记为 3NF.

理解范式

第一范式

  1. 每一列都是不可再分的属性值,保证每一列的原子性
  2. 相似的属性值应合并

第二范式

  1. 每一行的数据只能与其中一列相关,即一行数据只做一件事。只要数据列中出现数据重复,就要把表拆分开来。

举例:

一个订单号对应几个商品记录,此时订单号是重复的,应该拆分出来,保证数据不冗余

第三范式

  1. 数据不能存在传递关系,即没个属性都跟主键有直接关系而不是间接关系

结尾: 数据库的设计最终都是为了更符合业务,不用一昧的追求范式,再很多时候我们会反范式,比如为了增加查询速度,添加冗余数据等等

  • MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是最流行的关系型数据库管理系统之一。

    692 引用 • 535 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...