第22章_数据库的设计规范

文章目录

范式的概念

为了建立冗余较小、结构合理的数据库,设计数据库时必须遵循一定的规则。在关系型数据库中这种规则就称为范式。范式是符合某一种设计要求的总结。要想设计一个结构合理的关系型数据库,必须满足一定的范式。

三范式和反范式是空间和时间的关系。三范式是为了降低空间;反范式是通过增加空间来提升运行效率。

三范式

(1)目的:减少空间占用。

(2)内容:列不可分、依赖主键(联合索引)、在依赖主键(联合索引)的基础上直接依赖。

范式一

确保每列保持原子性;数据库表中的所有字段都是不可分解的

原子值;

例如:某表中有一个地址字段,如果经常需要访问地址字段中

的城市属性,则需要将该字段拆分为多个字段,省份、城市、

详细地址等;

范式二

确保表中的每列都和主键相关,而不能只与主键的某一部分相关(组合索引);

因为订单编号与客户的信息相关,订单编号和商品编号一起唯一确定数量,商品编号和商品信息相关;所以可以拆分成三个表:

范式三

确保每列都和主键直接相关,而不是间接相关;减少数据冗余;

例如

因为客户名称、所属公司、联系方式是和客户编号直接相关的,而客户编号跟订单编号是直接相关的,所以可以拆分为


反范式

反范式是经常使用的设计。比如用户表采用的就是反范式,因为如果用户表不采用反范式设计,将会产生很多的关联关系表,这就会涉及到联表查询,非常影响效率,特别对登录来说,是不可容忍的。

因此,反范式允许冗余存储,为了提升查询效率。

总结

  1. 范式二中,对于联合索引,主键不能依赖一部分,而要依赖整体;出现重复的要拆分。
  2. 反范式是经常使用的设计。三范式可以避免数据冗余,减少数据库的空间,减小维护数据完整性的麻烦。但是采用数据库范式化设计,可能导致数据库业务涉及的表变多,并且造成更多的联表查询,将导致整个系统的性能降低。因此处于性能考虑,可能需要进行反范式设计。
相关推荐
cyber_两只龙宝11 分钟前
【MySQL】MySQL主从复制架构
linux·运维·数据库·mysql·云原生·架构
xiaoye370843 分钟前
docker 迁移mysql容器
mysql·docker
橘颂TA43 分钟前
【MySQL】内置函数
数据库·mysql
橘颂TA1 小时前
【MySQL】使用C/C++来连接 MySQL
数据库·mysql
Y001112361 小时前
Day2-MySQL-SQL-1
sql·mysql·oracle
艾莉丝努力练剑2 小时前
【Linux进程间通信:共享内存】为什么共享内存的 key 值由用户设置
java·linux·运维·服务器·开发语言·数据库·mysql
天若有情6732 小时前
【实战】从零开发企业级 B 端风格字符串值管理系统(Python+MySQL)
开发语言·python·mysql·企业级应用·b端应用
m0_635647483 小时前
Qt开发与MySQL数据库教程(二)——MySQL常用命令以及示例
java·开发语言·数据库·mysql
予枫的编程笔记3 小时前
【面试专栏 | MySQL】MySQL事务底层实现拆解:Redo/Undo Log+锁+MVCC,一文讲透ACID
mysql·redo log·mvcc·数据库锁·undo log·事务原理·面试干货
程序员榴莲3 小时前
MySQL (一):MySQL的安装与启动
数据库·mysql