简单理解数据库三大范式

最近恶补一些大学的理论知识,感觉久了不看就忘了,在此简单地总结一下自己理解的范式。

一、首先简单介绍一下范式的历史:

对于范式主要是E.F.Codd做了大量的工作,1971~1972年他系统地提出了1NF、2NF和3NF的概念,讨论了规范化的问题。1974年,Codd和Boyce共同提出了一个新的范式,即BCNF。1976年,Fagin又提出了4NF,后来又有人提出了5NF。即级别为1NF-->2NF-->3NF-->BCNF-->4NF-->5NF,不过我们平时一般的设计只需满足前3大范式就差不多了,除非一些要求特别严格的才会考虑后面的。

二、其次简单介绍一些范式的概念:

关系数据库中的关系必须满足一定的要求,满足不同程度要求即为不同范式。满足最低要求的叫第一范式,简称1NF,在第一范式基础上满足进一步要求的成为第二范式,其余以此类推。范式越高,规范化程度越高,关系模式越好。

三、简单的理解一下前3大范式:

1、第一范式(1NF、原子性,不可拆分)

如果一个表中的每个字段是不可拆分,则可称它满足1NF,例如:

员工信息表
姓名 性别 家庭住址 所在部门名称 所在部门简介
张三 四川省成都市 研发部 专注于开发一系列软件产品..
小凤 四川省达州市 研发部 专注于开发一系列软件产品..
此表中如果省份和城市是可以单独管理的话,则“家庭住址”栏是可以拆分的,即可以拆分成省和市,如下拆分后才满足第1NF:

姓名 性别 家庭地址所在省 家庭地址所在市 所在部门名称 所在部门简介
张三 四川省 成都市 研发部 专注于开发一系列软件产品..
小凤 四川省 达州市 研发部 专注于开发一系列软件产品..

2、第二范式(2NF、唯一性,不可重复)

在满足1NF的情况下,保持表中每行数据的唯一性,即有唯一性的标识(一般习惯用主键(可以是复合主键)作为唯一标识),如在1中的员工信息表中完善:

编号 姓名 性别 家庭地址所在省 家庭地址所在市 所在部门名称 所在部门简介
1 张三 四川省 成都市 研发部 专注于开发一系列软件产品..
2 小凤 四川省 达州市 研发部 专注于开发一系列软件产品..
其中的编号是唯一的,这时才满足第2NF。

3、第三范式(3NF、直接依赖性、不可间接依赖)

在2NF中的“所在部门名称”依赖编号,“所在部门简介”既可依赖编号,也可依赖所在部门名称,即每个部门都会有相应的简介。此种情况不符合第3NF,经过如下改进后即可满足第3NF:

员工信息表
编号 姓名 性别 家庭地址所在省 家庭地址所在市 所在部门编号
1 张三 四川省 成都市 1
2 小凤 四川省 达州市 2
部门信息表
部门编号 部门名称 部门简介
1 研发部 专注于开发一系列软件产品..
2 市场部 主要是在外面接单子、推销产品等


你可能感兴趣的:(数据库,简介,三大范式)