[[IT知识]] 深度解析MySQL数据库设计三大范式:构建高效数据库结构的关键

[复制链接]
查看: 27|回复: 0
发表于 昨天 15:55 | 显示全部楼层 | 阅读模式
易博V9下载

深度解析MySQL数据库设计三大范式:构建高效数据库结构的关键


深度解析MySQL数据库设计三大范式:构建高效数据库结构的关键

1. 什么是设计范式


设计表的依据,按照范式设计出来的表,不会出现数据的冗余

数据库的设计范式是数据库设计所需要满足的规范,满足这些规范的数据库是简洁的、结构清晰的;反之则是乱七八糟,不仅会给开发人员制造麻烦,而且还可能存储了大量不需要的冗余数据

不仅仅只有三大范式,还有第四范式、第五范式、第六范式等,通常来讲,满足三大范式就基本足够

项目的数据库设计并不一定要完全满足于三大范式,有些时候我们会适量的冗余让 query 尽量减少 join

2. 三大范式


第一范式(1 NF):要求属性(列)具有原子性,即每列都是不可再分解的数据

虽然第一范式要求各列保存原子性,不能再分解,但是这种要求是和我们的需求相关联的,不拆分也行;如果要考虑可扩展性,那么就进行拆分吧。如下表所示,没有根据城市筛选用户的需求,可以这样存储城市数据

id name address
1 张三 河南省开封市兰考县
2 李四 广东省深圳市福田区

对 address 进行拆分,使其具有原子性(原子性:指不可再分解的意思)

id name province city area
1 张三 河南省 开封市 兰考县
2 李四 广东省 深圳市 福田区

第二范式(2 NF):建立在第一范式基础上,除主键外的每一列都必须完全依赖于主键

如果要出现不完全依赖主键,只可能发生在联合主键的情况下

第二范式是对记录的唯一性约束,要求有唯一性标识,即实体的唯一性,如下所示:即可 name 和 address 完全一致,但是主键值是不一样的,这样就实现了数据的唯一性

id name address
1 张三 河南省开封市兰考县
2 张三 河南省开封市兰考县

第三范式(3 NF):建立在第二范式基础上,对字段冗余性的约束,它要求字段没有冗余

假设员工的薪资水平由岗位决定,也就是 salary 由 job 决定,和人员(name)无关

员工表:

id name job salary
1 张三 Web 前端开发工程师 5000
2 李四 PHP 后端开发工程师 8000
3 王五 PHP 后端开发工程师 8000

那么,我们将遵循第三范式将员工表拆分为两张表,如下所示

员工表:

id name job_id
1 张三 100
2 李四 101
3 王五 101

薪资表:

id name salary
100 Web 前端开发工程师 5000
101 后端开发工程师 8000
易博软件介绍
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

1、请认真发帖,禁止回复纯表情,纯数字等无意义的内容!帖子内容不要太简单!
2、提倡文明上网,净化网络环境!抵制低俗不良违法有害信息。
3、如果你对主帖作者的帖子不屑一顾的话,请勿回帖。谢谢合作!
3、问答求助区发帖求助后,如有其他用户热心帮您解决问题后,请自觉点击设为最佳答案按钮。

 
 
QQ在线客服
QQ技术支持
工作时间:
8:00-18:00
软著登字:
1361266号
官方微信扫一扫
weixin

QQ|小黑屋|Archiver|慈众营销 ( 粤ICP备15049986号 )|网站地图

自动发帖软件 | 自动发帖器 | 营销推广软件 | 网络营销工具 | 网络营销软件 | 网站推广工具 | 网络推广软件 | 网络推广工具 | 网页推广软件 | 信息发布软件 | 网站推广工具 | 网页推广软件

Powered by Discuz! X3.4   © 2012-2020 Comsenz Inc.  慈众科技 - Collect from 深圳吉宝泰佛文化有限公司 公司地址:罗湖区黄贝街道深南东路集浩大厦A1403

返回顶部 返回列表