[原]数据库三范式

栏目: 数据库 · 发布时间: 7年前

内容简介:关系型数据库设计是很重要的一门学科,设计的好坏与否,直接影响到后续业务性能。遵从数据库方式进行数据库设计,将极大程度上是的数据冗余变少,后续整个数据库的性能,维护与管理都将变得轻松。设计数据库结构有六种范式,而最常用的莫过于一二三范式。本文将主要描述这三种范式。一、第一范式(1NF)1NF是对属性的原子性约束,要求属性(列)具有原子性,不可再分解。

关系型数据库设计是很重要的一门学科,设计的好坏与否,直接影响到后续业务性能。遵从数据库方式进行数据库设计,将极大程度上是的数据冗余变少,后续整个数据库的性能,维护与管理都将变得轻松。设计数据库结构有六种范式,而最常用的莫过于一二三范式。本文将主要描述这三种范式。

一、第一范式(1NF)

1NF是对属性的原子性约束,要求属性(列)具有原子性,不可再分解。

关系数据模型要求所有的关系模式必须满足第一范式。

非第一范式的例子

[原]数据库三范式

转换为第一范式

[原]数据库三范式

二、第二范式(2NF)

符合1NF,每一条记录存在惟一性约束,即实体的惟一性。

数据表里的所有属性(列)都要该表的主键有完全依赖关系。

如果有属性列只和主键的一部分(复合主键)有关的话,则应将其独立出来变成另一个数据表。

假定需要设计学生选课表,需要考虑以下信息:

学生有那些基本信息?

学生选了哪些课,成绩是什么?

每个课的学分是多少?

学生属于那个系,系的基本信息是什么?

不符合2NF示例

[原]数据库三范式

改进后的符合2NF示例

[原]数据库三范式

三、第三范式(3NF)

满足1NF,2NF且非主键字段之间不能有依赖关系或者表上不存在由非主键可推导出属性列。

三范式示例:

[原]数据库三范式

改进后的三范式

[原]数据库三范式

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

持续交付

持续交付

Jez Humble、David Farley / 乔梁 / 人民邮电出版社 / 2011-10 / 89.00元

Jez Humble编著的《持续交付(发布可靠软件的系统方法)》讲述如何实现更快、更可靠、低成本的自动化软件交付,描述了如何通过增加反馈,并改进开发人员、测试人员、运维人员和项目经理之间的协作来达到这个目标。《持续交付(发布可靠软件的系统方法)》由三部分组成。第一部分阐述了持续交付背后的一些原则,以及支持这些原则的实践。第二部分是本书的核心,全面讲述了部署流水线。第三部分围绕部署流水线的投入产出讨......一起来看看 《持续交付》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

MD5 加密
MD5 加密

MD5 加密工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器