当前位置: 主页 > 数据库

范式数据库-1范式转换2范式

发布时间:2023-03-10 07:12   浏览次数:次   作者:佚名

修改使表满足1NF后:

1范式转换2范式_范式数据库_数据库表设计的三范式

判断表是否符合第一范式,列是否可以再分,得看需求,如果将电话号和地址分开才能满足查询等需求时范式数据库,那之前的表设计就是不满足1NF的,如果电话号和地址拼接作为一个字段也可以满足查询、存储等需求时,那它就满足1NF。

第二范式 2NF

在满足1NF的前提下,表中不存在部分依赖,非主键列要完全依赖于主键。(主要是说在联合主键的情况下,非主键列不能只依赖于主键的一部分)

如下学生成绩表(score):

数据库表设计的三范式_范式数据库_1范式转换2范式

stu_id(学生id)、kc_id(课程id)、score(分数)、kc_name(课程名)

primary key(stu_id, kc_id)

在这里插入图片描述

表中主键为stu_id和kc_id组成的联合主键。满足1NF;非主键列score完全依赖于主键,stu_id和kc_id两个值才能决定score的值;而kc_name只依赖于kc_id,与stu_id没有依赖关系,它不完全依赖于主键,只依赖于主键的一部分,不符合2NF。

修改使表满足2NF后:

数据库表设计的三范式_范式数据库_1范式转换2范式

成绩表(score)   primary key(stu_id)

在这里插入图片描述

课程表(kc)   primary key(kc_id)

在这里插入图片描述

将原来的成绩表(score)拆分为成绩表(score)和课程表(kc),而且两个表都符合2NF。

范式数据库_数据库表设计的三范式_1范式转换2范式

第三范式 3NF:

在满足2NF的前提下,不存在传递依赖。(A -> B, B -> C, A->C)

如下学生信息表(student):

primary key(id)

在这里插入图片描述

范式数据库_数据库表设计的三范式_1范式转换2范式

表中sex_desc依赖于sex_code,而sex_code依赖于id(主键),从而推出sex_desc依赖于id(主键);sex_desc不直接依赖于主键,而是通过依赖于非主键列而依赖于主键,属于传递依赖范式数据库,不符合3NF。

修改表使满足3NF后:

学生表(student)   primary key(id)

在这里插入图片描述

性别代码表(sexcode)   primary key(sex_code)

范式数据库_1范式转换2范式_数据库表设计的三范式

在这里插入图片描述

将原来的student表进行拆分后,两个表都满足3NF。

什么样的表越容易符合3NF?

非主键列越少的表。(1NF强调列不可再分;2NF和3NF强调非主属性列和主属性列之间的关系)

如代码表(sexcode),非主键列只有一个sex_desc;

或者将学生表的主键设计为primary key(id,name,sex_code,phone),这样非主键列只有address,更容易符合3NF。