最近恶补一些大学的理论知识,感觉久了不看就忘了,在此简单地总结一下自己理解的范式。
一、首先简单介绍一下范式的历史:
对于范式主要是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,例如:
姓名 | 性别 | 家庭住址 | 所在部门名称 | 所在部门简介 |
张三 | 男 | 四川省成都市 | 研发部 | 专注于开发一系列软件产品.. |
小凤 | 女 | 四川省达州市 | 研发部 | 专注于开发一系列软件产品.. |
姓名 | 性别 | 家庭地址所在省 | 家庭地址所在市 | 所在部门名称 | 所在部门简介 |
张三 | 男 | 四川省 | 成都市 | 研发部 | 专注于开发一系列软件产品.. |
小凤 | 女 | 四川省 | 达州市 | 研发部 | 专注于开发一系列软件产品.. |
2、第二范式(2NF、唯一性,不可重复)
在满足1NF的情况下,保持表中每行数据的唯一性,即有唯一性的标识(一般习惯用主键(可以是复合主键)作为唯一标识),如在1中的员工信息表中完善:
编号 | 姓名 | 性别 | 家庭地址所在省 | 家庭地址所在市 | 所在部门名称 | 所在部门简介 |
1 | 张三 | 男 | 四川省 | 成都市 | 研发部 | 专注于开发一系列软件产品.. |
2 | 小凤 | 女 | 四川省 | 达州市 | 研发部 | 专注于开发一系列软件产品.. |
3、第三范式(3NF、直接依赖性、不可间接依赖)
在2NF中的“所在部门名称”依赖编号,“所在部门简介”既可依赖编号,也可依赖所在部门名称,即每个部门都会有相应的简介。此种情况不符合第3NF,经过如下改进后即可满足第3NF:
编号 | 姓名 | 性别 | 家庭地址所在省 | 家庭地址所在市 | 所在部门编号 |
1 | 张三 | 男 | 四川省 | 成都市 | 1 |
2 | 小凤 | 女 | 四川省 | 达州市 | 2 |
部门编号 | 部门名称 | 部门简介 |
1 | 研发部 | 专注于开发一系列软件产品.. |
2 | 市场部 | 主要是在外面接单子、推销产品等 |