范式是什么
规范的的数据库是需要满足一些规范的来优化数据数据存储方式。在关系型数据库中这些规范就可以称为范式。
什么是三大范式:
第一范式:当关系模式 R 的所有属性都不能在分解为更基本的数据单位时,称 R 是满足第一范式的,简记为 1NF。满足第一范式是关系模式规范化的最低要求,否则,将有很多基本操作在这样的关系模式中实现不了。
第二范式:如果关系模式 R 满足第一范式,并且 R 得所有非主属性都完全依赖于 R 的每一个候选关键属性,称 R 满足第二范式,简记为 2NF。
第三范式:设 R 是一个满足第一范式条件的关系模式,X 是 R 的任意属性集,如果 X 非传递依赖于 R 的任意一个候选关键字,称 R 满足第三范式,简记为 3NF.
理解范式
第一范式
- 每一列都是不可再分的属性值,保证每一列的原子性
- 相似的属性值应合并
第二范式
- 每一行的数据只能与其中一列相关,即一行数据只做一件事。只要数据列中出现数据重复,就要把表拆分开来。
举例:
一个订单号对应几个商品记录,此时订单号是重复的,应该拆分出来,保证数据不冗余
第三范式
- 数据不能存在传递关系,即没个属性都跟主键有直接关系而不是间接关系
结尾: 数据库的设计最终都是为了更符合业务,不用一昧的追求范式,再很多时候我们会反范式,比如为了增加查询速度,添加冗余数据等等
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于