您的位置:首页 > 数据库

简单理解数据库三大范式

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

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

对于范式主要是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市场部主要是在外面接单子、推销产品等
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息