数据库范式
标签:数据库
前置知识
码
唯一标识和区分数据记录的列或列组合。
empno
ename
deptno
其中empno
就能唯一标示一行数据了,是码(empno=1
的只有一行数据)
sno学号
cno课程号
grade分数
其中sno
和cno
两个才能唯一标示一行数据,sno
和cno
的组合属于码,其中单独一个不属于码(sno
=1的可能不止一行数据,一个学生可以有多门课,cno
=1的也可能不止一条数据,一门课可以被多个学生选,sno
=1 and cno
= 1的最多只能有一条)
主属性与非主属性
主属性:码中的列
非主属性:出了码中列之外的其他列
函数依赖关系
全部依赖
f(sno,cno)->grade
部分依赖
f(sno,cno)->dept,dept只依赖与sno(依赖与码中的部分)
传递依赖
f(sno,cno)->loc,通过sno就能知道dept,通过dept就能知道loc,所以通过sno能间接知道loc
范式的意义
-
消除冗余
-
消除增删改异常
sno
dept
loc
增:在没有学生之前,系与系地址就确定了,怎么存储这种关系
删:学生全部删除了,系与系地址的关系也没了
改:系地址变了,需要改该系所有同学的系地址(修改多行数据,修改的复杂性)
1NF
列的原子性
sno
cno
grade
dept
loc
2NF
不能有非主属性对主属性的部分函数依赖(一般存在主属性有多个的情况,比如sno
and cno
)
sno
cno
grade
sno
dept
loc
3NF
不能有非主属性对主属性的传递函数依赖关系(非主属性之间不能有函数依赖关系)
sno
cno
grade
sno
dept
dept
loc
BCNF
两种理解:
- 主属性之间不能有部分或传递函数依赖(主属性只有一个的时候不存在内部)
- 所有函数依赖关系x->y中,x一定是主属性(主属性只有一个的时候一定满足)
sno
cno
grade
两个主属性之间没有函数依赖关系
sno
dept
只有一个主属性
dept
loc
只有一个主属性
多值依赖
x->->y一个x能推导出多个y
4NF
4NF 非函数依赖范畴,是多值依赖范畴几遍满足BCNF也存在冗余与增删改异常
课程
老师
参考资料
(一门课可以有多个老师带,一门课可以有多本参考资料)
拆成两张表
课程
老师
课程
参考资料