在自主学习DB的过程中,一直对函数依赖很模糊,看不懂书上的所以然。后来,经过名师指导,终于豁然开朗了,至少我自己能根据自己的理解知道“函数依赖”是个什么东西。一下就是我的理解!
函数依赖是关键码的推广,可以理解为属性之间存在的一种决定关系。
函数依赖
举例:有一关系,学生(学号,姓名<不重复>,性别)
每一个“学号”只能对应一个“姓名”,也就是一个“学号”对应一名同学,不能对应多名。这就是函数依赖!
局部依赖
举例:学生(学号,课程号,姓名<不重复>,成绩)
在这个关系中,“学号”和“课程号”构成主键,非主属性是“姓名”和“成绩”。主键可以决定“姓名”,同时主键中的主属性“学号”也可以决定“姓名”。这就是局部依赖!
传递依赖
举例:学生(学号,专业,宿舍地址<单属性>)
在这个关系中,结合我们的生活,“学号”决定“专业”和“宿舍地址”,但“专业”不能决定“学号”,且“专业”也可以决定“宿舍地址”,那么“学号”与“宿舍地址”就形成了传递依赖!
多值依赖
从字面上可以理解为,关系r的某个属性为多值属性,只要两个独立的1:N联系出现在一个关系中,就有可能形成多值依赖。
局部VS传递
传递:主键决定属性1,属性1决定属性2 (注意:属性1可为主或非主属性,属性2为非主)
小结