在线客服
扫描二维码
下载博学谷APP扫描二维码
关注博学谷微信公众号
数据库设计之三范式是什么?有什么作用?范式:是对设计数据库提出的一些规范,设计数据库时遵循一定的规则,建立冗余较小、结构合理的数据库更便于查找数据。
学习目标:知道一个表结构的设计是否符合三范式的要求
1. 数据库设计之三范式是什么?
范式: 对设计数据库提出的一些规范,目前有迹可寻的共有8种范式一般遵守3范式即可。
第一范式(1NF): 强调的是列的原子性即列不能够再分成其他几列。
第二范式(2NF): 满足 1NF,另外包含两部分内容,表必须有一个主键,非主键字段必须完全依赖于主键而不能只依赖于主键的一部分。
第三范式(3NF): 满足 2NF,另外非主键列必须直接依赖于主键,不能存在传递依赖。即不能存在:非主键列 A 依赖于非主键列 B,非主键列 B 依赖于主键的情况。
2. 第一范式(1NF)
如图所示的表结构:
说明:这种表结构设计就没有达到 1NF,要符合 1NF 我们只需把列拆分,即:把 contact 字段拆分成 name 、tel、addr 等字段。
3. 第二范式(2NF)
如图所示的表结构:
说明:这种表结构设计就没有达到 2NF,因为 Discount(折扣),Quantity(数量)完全依赖于主键(OrderID),而 UnitPrice单价,ProductName产品名称 只依赖于 ProductID, 所以 OrderDetail 表不符合 2NF。
我们可以把【OrderDetail】表拆分为【OrderDetail】(OrderID,ProductID,Discount,Quantity)和【Product】(ProductID,UnitPrice,ProductName)这样就符合第二范式了。
4. 第三范式(3NF)
如图所示的表结构:
说明:这种表结构设计就没有达到 3NF,因为 OrderDate,CustomerID,CustomerName,CustomerAddr,CustomerCity 等非主键列都完全依赖于主键(OrderID),所以符合 2NF。不过问题是 CustomerName,CustomerAddr,CustomerCity 直接依赖的是 CustomerID(非主键列),而不是直接依赖于主键,它是通过传递才依赖于主键,所以不符合 3NF。
我们可以把【Order】表拆分为【Order】(OrderID,OrderDate,CustomerID)和【Customer】(CustomerID,CustomerName,CustomerAddr,CustomerCity)从而达到 3NF。
5. E-R模型的介绍
E-R模型即实体-关系模型,E-R模型就是描述数据库存储数据的结构模型。
E-R模型的使用场景:对于大型公司开发项目,我们需要根据产品经理的设计,我们先使用建模工具, 如:power designer,db desinger等这些软件来画出实体-关系模型(E-R模型)。然后根据三范式设计数据库表结构,E-R模型的效果图:
说明:实体:用矩形表示,并标注实体名称;属性: 用椭圆表示,并标注属性名称;关系: 用菱形表示,并标注关系名称(一对一,一对多,多对多)
(1)一对一的关系:
说明:关系也是一种数据,需要通过一个字段存储在表中,1对1关系,在表A或表B中创建一个字段,存储另一个表的主键值
(2)一对多的关系:
说明:1对多关系,在多的一方表(学生表)中创建一个字段,存储班级表的主键值
(3)多对多的关系:
说明:多对多关系,新建一张表C,这个表只有两个字段,一个用于存储A的主键值,一个用于存储B的主键值
5. 小结
范式就是设计数据库的一些通用规范。
1NF强调字段是最小单元,不可再分
2NF强调在1NF基础上必须要有主键和非主键字段必须完全依赖于主键,也就是说 不能部分依赖
3MF强调在2NF基础上 非主键字段必须直接依赖于主键,也就是说不能传递依赖(间接依赖)。
E-R模型由 实体、属性、实体之间的关系构成,主要用来描述数据库中表结构。
开发流程是先画出E-R模型,然后根据三范式设计数据库中的表结构
— 申请免费试学名额 —
在职想转行提升,担心学不会?根据个人情况规划学习路线,闯关式自适应学习模式保证学习效果
讲师一对一辅导,在线答疑解惑,指导就业!
相关推荐 更多
Python知识点详解:UDP和TCP协议的介绍
UDP和TCP都是传输层协议,不过却又一些不同。TVP提供IP环境下的数据可靠传输,它是实现为所发送的数据凯皮出连接的通道,然后再进行数据的发送。而UDP并不为IP提供可靠性,流控或差错回复功能。UDP和TCP到底如何定义?应用场景是如何的呢?下面小编就详细为大家解析一下。
7882
2019-07-11 17:18:53
博学谷零基础Python入门课程学什么?好不好?
众所周知,Python 是一个高层次的结合了解释性、编译性、互动性和面向对象的脚本语言。博学谷为零基础的同学推出了Python入门课程,为同学们介绍了Python简介、Python执行方式和Pycharm设置、程序执行原理、变量、循环语句及函数,希望大家通过课程快速入门Python。
7362
2019-07-23 17:35:29
Python五大应用领域
Python五大应用领域,要说近两年最火的编程语言是什么?毫无疑问是Python,而且不仅是编程人员、为做论文数据的研究生、职场人士纷纷加入Python学习大军。而市面上的Python课程也会针对大家不同需求进行调整。对于想要通过Python学习获得一份工作的朋友,对于Python的应用领域必须了解。
4815
2020-06-12 14:32:11
怎么学习Python语言获得一技之长?
怎么学习Python语言?Python语言的语法结构简单比较适合零基础人群作为第一门编程语言来学习。建议制定一个系统的学习计划,一个连续学习编程语言的过程,学习Python理论,练习小项目积累实操经验。
4339
2020-07-10 10:20:22
HTTP协议的作用是什么?怎么用?
HTTP协议的作用是什么?怎么用?HTTP协议超文本传输协议,传输HTTP 协议格式的数据是基于 TCP 传输协议的,发送数据之前需要先建立连接。
4943
2021-12-17 16:17:58
热门文章
- 前端是什么
- 前端开发的工作职责
- 前端开发需要会什么?先掌握这三大核心关键技术
- 前端开发的工作方向有哪些?
- 简历加分-4步写出HR想要的简历
- 程序员如何突击面试?两大招带你拿下面试官
- 程序员面试技巧
- 架构师的厉害之处竟然是这……
- 架构师书籍推荐
- 懂了这些,才能成为架构师 查看更多
扫描二维码,了解更多信息
