数据库三范式与反范式详解(一看就懂)

范式与反范式

  • 范式化设计
    通过满足下面提出的三条范式规则,尽可能的避免出现数据冗余
    因为数据冗余会带来,数据UPDATE更新遗漏问题(毕竟SQL是人写的~)
  • 反范式化设计
    目的是,用空间换时间,通过适当的数据冗余(8张不同业务的表结构内,都存在“”联系人电话“”字段)
    这样,虽然存储的数据字段,不是用户ID,导致数据量增大,但是查询时不需要通过联查,可以提高查询效率

1.第一范式

  • 第一范式:要求表中业务字段,逻辑上不可再分
    如图:错误设计,和两种正确设计在这里插入图片描述

2.第二范式

  • 第二范式:要求表中必须存在业务主键 (单一业务主键 或 联合业务主键),非业务主键,必须依赖于 单一业务主键 或 全部的联合业务主键
    如图:错误设计,和正确设计在这里插入图片描述

3.第三范式

  • 第三范式:要求非业务主键列不能相互依赖
    如图:错误设计,和正确设计在这里插入图片描述

4.反范式

  • 反范式化设计数据库,是为了提高查询效率,采用空间换时间的实现思路
  • 一些情况下
    比如 存在频繁查询时,可以容忍适当的冗余设计,目的是减少多表关联查询,提高效率
    例如:订单表中冗余了商品信息和用户相关信息,避免查询订单时关联用户表和商品表去查询相关信息,提高效率
  • 好查不好改
    但是冗余意味着,好查不好改,修改数据时
    冗余设计造成需要同时修改多张表中的某些字段
    容易出现业务上的Update遗漏现象(毕竟SQL是人写的~)



搞 定 撒 花 ❀❀❀❀❀❀❀❀❀❀❀❀

  • 5
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

长毛山顶洞人

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值