【MySQL 流浪之旅】 第五讲 数据库设计的三个范式

系列文章目录

【MySQL 流浪之旅】 第一讲 MySQL 安装
【MySQL 流浪之旅】 第二讲 MySQL 基础操作
【MySQL 流浪之旅】 第三讲 MySQL 基本工具
【MySQL 流浪之旅】 第四讲 MySQL 逻辑备份


前言

数据库的设计三范式(Normalization)是关系型数据库设计的一种标准化过程,目的是消除冗余数据,提高数据存储的效率和数据查询的性能。

三个范式分别是:

  • 第一范式(1NF):也称为原子性原则,要求数据库表中的每一列都是不可再分的最小数据单元,即所有域都应该是原子性的,即实体中的某个属性有多个值时,必须拆分为不同的属性。在符合第一范式(1NF)表中的每个域值只能是实体的一个属性或一个属性的一部分。
  • 第二范式(2NF):在第一范式(1NF)的基础上,非主键字段必须依赖于主键。这意味着非主键列不能只依赖于主键的一部分,而是必须完全依赖于主键。此外,非主属性不能与非主属性之间有依赖关系,非主属性必须直接依赖于主属性,不能间接依赖主属性。
  • 第三范式(3NF):在满足第二范式(2NF)的基础上,除了主键以外的其它列都不能传递依赖于主键列的信息。也就是说,任何非主属性不能依赖于其它非主属性。简而言之,第三范式就是在1NF基础上,除了主键以外的其它列都不传递依赖于主键列,或者说:任何非主属性不依赖于其它非主属性。

下面简单展开讲讲。

一、第一范式

1.1. 设计原则

  • 数据库所有字段都只有单一属性
  • 单一属性是由基本数据类型构成的
  • 数据库的表都是二维的(行与列)

1.2. 错误范例

二、第二范式

2.1. 设计原则

  • 要求符合第一范式
  • 表必须有一个主键(一列或多列)
  • 其他字段可由主键确定
  • 二范式目的是通过拆表减少数据冗余

2.2. 设计样例

三、第三范式

3.1. 设计原则

  • 要求符合第二范式
  • 字段要求直接依赖于主键,不允许间接依赖
  • 第三范式目的在于拆分实体(完善主从表)

3.2. 设计样例

相关推荐
BryceBorder8 分钟前
SCAU--数据库
数据库·oracle·dba
java1234_小锋10 分钟前
MySQL中的乐观锁和悲观锁是什么?
mysql
有味道的男人13 分钟前
京东关键词API接口获取
数据库
罗光记30 分钟前
《人工智能安全治理研究报告(2025年)发布
数据库·其他·百度·新浪微博
202321336054 刘1 小时前
Linux常用命令分类整理
linux·运维·数据库
Q741_1471 小时前
海致星图招聘 数据库内核研发实习生 一轮笔试 总结复盘(2) 作答语言:C/C++ 哈夫曼编码 LRU
c语言·数据库·c++·算法·笔试·哈夫曼编码·哈夫曼树
齐 飞1 小时前
快速删除mysql表中所有数据-TRUNCATE TABLE
数据库·mysql
想摆烂的不会研究的研究生1 小时前
每日八股——Redis(2)
数据库·redis·缓存
optimistic_chen1 小时前
【Redis系列】主从复制
linux·数据库·redis·缓存·中间件·命令行·主从复制
一个天蝎座 白勺 程序猿1 小时前
KingbaseES 处理 PL/SQL 运行时错误全解析:从异常捕获到异常处理的实践指南
数据库·sql·oracle·kingbasees