数据库的设计
参考文献:https://blog.csdn.net/hanxueyu666/article/details/81587199
1、多表之间的关系
1.1、分类:
(1)、一对一(只做了解)
* 比如:某个人和它的身份证
* 分析:一个人只要一个身份证,一个身份证只能对应一个人。
(2)、一对多(或叫多对一)
* 如:部门和员工
* 分析:一个部门多有个员工,一个员工只能对应一个部门
(3)、多对多:
* 如:学生和课程
* 分析:一个学生可以选择很多课程,一个课程可以被很多学生选择。
1.2、实现关系
(1)、一对一(只做了解)
* 比如:某个人和它的身份证
* 实现方式:一堆一关系实现,可以在任意放添加 唯一外键 指向另外一方的主键
(2)、一对多(或叫多对一)
* 如:部门和员工
* 实现方式:在‘多’的一方建立外键,执行‘一’的一方的主键,比如在员工表单中建立一个外键执行部门表单中的主键。
(3)、多对多:
* 如:学生和课程
* 实现方式:多对多关系实现需要借助第三方中间表。中间表包含两个字段(联合主键),并使用这两个字段作为外键,分别指向两张表的主键。
2、范式
(1)概念:要设计数据库,必须遵循一定规范,应用后面的范式必须遵循前面的范式。
设计关系数据库时,遵从不同的规范要求,设计出合理的关系型数据库,这些不同的规范要求被称为不同的范式,各种范式呈递次规范,越高的范式数据库冗余越小。
(2)、分类
名词解释:
①、函数依赖:A->B,如果通过A属性(或属性组)的值,可以确定唯一B属性的值,称B依赖A。
例如:学号->姓名 (学号,课程名称)->分数
②、完全函数依赖:A->B,如果A是一个属性组,则确定B属性需要依赖于A属性值组中所有的属性值。
例如:(学号,课程名称)->分数
③、部分函数依赖:A->B,如果A是一个属性组,则确定B属性值需要A属性组中的某一些值即可。
④、传递函数依赖:A->B,B->C,如果通过A属性(属性组)的值,可以确定唯一B属性的值,再通过B属性(属性组)的值可以确定唯一的C属性值,则称C传递函数依赖于A.
举例:学号->系名,系名->系主任
⑤、码:如果一张表中,一个属性或属性组,被其它所有属性完全依赖,则称这个属性(属性组为该表的码):
*主属性:码属性中的所有属性。
*非主属性:除码属性组外的属性。
目前关系数据库有六种范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、巴斯-科德范式(BCNF)、第四范式(4NF)和第五范式(5NF,又称完美范式)。
a、第一范式(1NF)。数据库表的每一列都是不可分割的原子数据项,而不能是集合,数组,记录等非原子数据项。数据库表的每一列都是不可分割的原子数据项,而不能是集合,数组,记录等非原子数据项。
b、第二范式(2NF)。在第一范式的基础上,消除非主属性对 码 的部分函数依赖
c、第三范式(3NF)。在2NF基础上消除 传递依赖。