唯一标识和区分数据记录的列或列组合。
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
增:在没有学生之前,系与系地址就确定了,怎么存储这种关系
删:学生全部删除了,系与系地址的关系也没了
改:系地址变了,需要改该系所有同学的系地址(修改多行数据,修改的复杂性)
列的原子性
sno
cno
grade
dept
loc
不能有非主属性对主属性的部分函数依赖(一般存在主属性有多个的情况,比如sno
and cno
)
sno
cno
grade
sno
dept
loc
不能有非主属性对主属性的传递函数依赖关系(非主属性之间不能有函数依赖关系)
sno
cno
grade
sno
dept
dept
loc
两种理解:
sno
cno
grade
两个主属性之间没有函数依赖关系
sno
dept
只有一个主属性
dept
loc
只有一个主属性
x->->y一个x能推导出多个y
4NF 非函数依赖范畴,是多值依赖范畴几遍满足BCNF也存在冗余与增删改异常
课程
老师
参考资料
(一门课可以有多个老师带,一门课可以有多本参考资料)
拆成两张表
课程
老师
课程
参考资料