唯一标识和区分数据记录的列或列组合。
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也存在冗余与增删改异常
课程 老师 参考资料(一门课可以有多个老师带,一门课可以有多本参考资料)
拆成两张表
课程 老师
课程 参考资料