数据库:三大范式

        
第一范式:
第一范式(1NF)是指数据库表的每一列都是不可分割的基本数据项,同一列中不能有多个值,即实体中的某个属性不能有多个值或者不能有重复的属性。如果出现重复的属性,就可能需要定义一个新的实体,新的实体由重复的属性构成,新实体与原实体之间为一对多关系。在第一范式(1NF)中表的每一行只包含一个实例的信息。简而言之,第一范式就是无重复的列。
符合1NF的关系中的每个属性都不可再分
下表不是1NF:
在这里插入图片描述
举例:
每个字段都只能存放单一值

学号 课程
1 数学
1 英语
2 语文

每笔记录都要能利用一个惟一的主键来加以识别,不能出现重复组

学号 课程 班级
1 数学 2班
2 数学 2班

第一范式是对关系模式的基本要求
第二范式
第二范式(2NF)是在第一范式(1NF)的基础上建立起来的,即满足第二范式(2NF)必须先满足第一范式(1NF)。第二范式(2NF)要求数据库表中的每个实例或行必须可以被惟一地区分。为实现区分通常需要为表加上一个列,以存储各个实例的惟一标识。例如员工信息表中加上了员工编号(emp_id)列,因为每个员工的员工编号是惟一的,因此每个员工可以被惟一区分。这个惟一属性列被称为主关键字或主键、主码。
== 第二范式(2NF)要求实体的属性完全依赖于主关键字==
表一

学号 课程 分数
1 数学 99

表二

学号 班级 班主任
1 2班 老班

第三范式
满足第三范式(3NF)必须先满足第二范式(2NF)。简而言之,第三范式(3NF)要求一个数据库表中不包含已在其它表中已包含的非主关键字信息。例如,存在一个部门信息表,其中每个部门有部门编号(dept_id)、部门名称、部门简介等信息。那么在的员工信息表中列出部门编号后就不能再将部门名称、部门简介等与部门有关的信息再加入员工信息表中。如果不存在部门信息表,则根据第三范式(3NF)也应该构建它,否则就会有大量的数据冗余。
第三范式就是属性不依赖于其它非主属性。 也就是说, 如果存在非主属性对于码的传递函数依赖,则不符合3NF的要求。

学号 班主任
1 老班
学号 班级
1 2班

下边不符合3NF,知道了班级,同样也就知道了班主任,称班级传递依赖于码(学号)

学号 班级 班主任
1 2班 老班
发布了39 篇原创文章 · 获赞 1 · 访问量 1162

猜你喜欢

转载自blog.csdn.net/alidingding/article/details/104587298