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