数据库的三范式是什么?

第一范式(1NF)

每列的原子性,表中的每一个字段都是不可分割的,同一列中不能有多个值。第一范式是对关系模式的基本要求,不满足第一范式的数据库不是关系型数据库。

・不满足第一范式的示例:

|----------|----------|------------------------------------------------------------------------------------------------|
| 学生编号 | 学生姓名 | 联系方式 |
| 1001 | 张三 | zs@gmail.com, 13599999999 |
| 1002 | 李四 | ls@gmail.com, 13699999999 |
| 1003 | 王五 | ww@163.net, 13488888888 |

第二范式(2NF)

确保唯一性和依赖性,每个表都有主键,且其他字段都完全依赖主键。

第二范式是在第一范式的基础上,要求表中的每一条数据可以被唯一区分,通常使用主键实现,其他所有字段都完全依赖主键。

其他字段依赖主键是指,其他每个字段都与主键完全相关,当确定主键的值时就能确定其他所有字段的值。也就是说一个表只能存一种数据,不可以把多种数据存到一个表中。

完全依赖是指,联合主键时,其他字段不可以只依赖主键中的某个字段,必须依赖联合主键中的每一个字段。

・不满足第二范式的示例:

|----------|----------|----------|--------|
| 学生编号 | 课程编号 | 学生姓名 | 成绩 |
| 1001 | 001 | 张三 | 90 |
| 1002 | 001 | 李四 | 80 |
| 1001 | 002 | 张三 | 90 |

第三范式(3NF)

在第二范式的基础上,非主键字段必须直接依赖于主键,不能存在传递依赖。

・不满足第三范式的示例:

|----------|----------|----------|---------|
| 学生编号 | 班级编号 | 学生姓名 | 班级名 |
| 1001 | 01 | 张三 | 一年一班 |
| 1002 | 02 | 李四 | 一年二班 |
| 1003 | 03 | 王五 | 一年三班 |

班级名对学生编号和班级编号产生了传递依赖

相关推荐
014-code几秒前
Spring 事务原理深度解析
java·数据库·spring·oracle
xixihaha13246 分钟前
实战:用OpenCV和Python进行人脸识别
jvm·数据库·python
云边有个稻草人9 分钟前
Oracle替换工程实践深度解析:金仓数据库的“去O”攻坚之路
数据库
泯仲13 分钟前
从零起步学习MySQL 第十三章:MySQL 事务详解:原理、特性、并发问题与隔离级别
数据库·学习·mysql
嚴寒13 分钟前
云服务核心组件:OSS 与 RDS 全面指南(2026版)
数据库·后端·架构
G探险者16 分钟前
DDD开发模式说明
java·运维·数据库
TDengine (老段)16 分钟前
TDengine IDMP 组态面板 —— 图元
大数据·数据库·人工智能·物联网·时序数据库·tdengine
马里马里奥-17 分钟前
文献阅读:LinkAlign:面向真实世界大规模多数据库文本转SQL任务的可扩展模式链接方法
数据库·sql
FITA阿泽要努力18 分钟前
《通过实战SQL学会CTE、CURRENT_DATE、CURDATE()、DATE_SUB与缩进&注释的问题》
数据库
爬山算法19 分钟前
MongoDB(42)如何使用$project阶段?
数据库·mongodb