【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. 设计样例

相关推荐
瓯雅爱分享6 分钟前
Java+Vue构建的采购招投标一体化管理系统,集成招标计划、投标审核、在线竞价、中标公示及合同跟踪功能,附完整源码,助力企业实现采购全流程自动化与规范化
java·mysql·vue·软件工程·源代码管理
BTU_YC2 小时前
Neo4j查询计划完全指南:读懂数据库的“执行蓝图“
数据库·neo4j
非极限码农2 小时前
Neo4j图数据库上手指南
大数据·数据库·数据分析·neo4j
mit6.8242 小时前
[C# starter-kit] 命令/查询职责分离CQRS | MediatR |
java·数据库·c#
咋吃都不胖lyh3 小时前
SQL-多对多关系
android·mysql·数据分析
苏打水com3 小时前
数据库进阶实战:从性能优化到分布式架构的核心突破
数据库·后端
shan~~4 小时前
linux达梦数据库操作
linux·数据库·chrome
武文斌774 小时前
项目学习总结:LVGL图形参数动态变化、开发板的GDB调试、sqlite3移植、MQTT协议、心跳包
linux·开发语言·网络·arm开发·数据库·嵌入式硬件·学习
CoderIsArt5 小时前
SQLite架构
数据库·sqlite
lixora5 小时前
银河麒麟高级服务器操作系统(ADM64 版)V10(SP1)搭建 Oracle 19c RAC
数据库