范式的简单介绍:
记得前段时间课程设计,答辩时,老师的第一个问题是:你的数据库表满足第几范式了?我的第一反应是:范式?什么范式?于是老师连看都没看的就把我打发走了。看样子,范式还挺重要的,于是,抱起书本就看,可是,书上有关范式的讲解可能太深奥了,完全不懂,看完只感到头疼,其他什么印象都没有,于是只能百度一下了。
以下内容是从网上各种搜集,再加上自己的理解,然后总结,整理了之后记录下来,说不定以后会用到。
为了建立冗余较小、结构合理的数据库,设计数据库时必须遵循一定的规则。在关系型数据库中这种规则就称为范式,范式是符合某一种设计要求的总结。要想设计一个结构合理的关系型数据库,必须满足一定的范式;
目前,主要有六种范式:第一范式、第二范式、第三范式、BC范式、第四范式和第五范式。满足最低要求的叫第一范式,简称1NF。在第一范式基础上进一步满足一些要求的为第二范式,简称2NF,其余依此类推;
在实际开发中最为常见的设计范式是这三个:
1.第一范式
第一范式是最基本的范式,如果数据库表中有主键,并且表中的所有字段值都是不可分解的原子值,就说明该数据库表满足了第一范式。
第一范式的合理遵循需要根据系统的实际需求来定。比如某些数据库系统中需要用到“地址”这个属性,本来直接将“地址”属性设计成一个数据库表的字段就行。但是如果系统经常会访问“地址”属性中的“城市”部分,那么就非要将“地址”这个属性重新拆分为省份、城市、详细地址等多个部分进行存储,这样在对地址中某一部分操作的时候将非常方便。这样设计才算满足了数据库的第一范式,如下表所示。
用户信息表
编号 |
姓名 |
性别 |
年龄 |
联系电话 |
省份 |
城市 |
详细地址 |
1 |
张红欣 |
男 |
26 |
0378-23459876 |
河南 |
开封 |
朝阳区新华路23号 |
2 |
李四平 |
女 |
32 |
0751-65432584 |
广州 |
广东 |
白云区天明路148号 |
3 |
刘志国 |
男 |
21 |
0371-87659852 |
河南 |
郑州 |
二七区大学路198号 |
4 |
郭小明 |
女 |
27 |
0371-62556789 |
河南 |
郑州 |
新郑市薛店北街218号 |
上表所示的用户信息遵循了第一范式的要求,这样在对用户使用城市进行分类的时候就非常方便,也提高了数据库的性能。
2.第二范式
第二范式在第一范式的基础之上更进一层。第二范式需要确保数据库表中的每一列都和主键相关,而不能只与主键的某一部分相关(主要针对联合主键而言)。也就是说在一个数据库表中,一个表中只能保存一种数据,不可以把多种数据保存在同一张数据库表中。
如选课关系表为SelectCourse(学号, 姓名, 年龄, 课程名称, 成绩, 学分),主键为联合主键(学号, 课程名称),因为存在如下决定关系:
(学号, 课程名称) → (姓名, 年龄, 成绩, 学分)
这个数据库表不满足第二范式,因为存在如下决定关系:
(课程名称) → (学分)
(学号) → (姓名, 年龄)
由于不符合2NF,这个选课关系表会存在如下问题:
(1) 数据冗余: