【DB】函数依赖

     在自主学习DB的过程中,一直对函数依赖很模糊,看不懂书上的所以然。后来,经过名师指导,终于豁然开朗了,至少我自己能根据自己的理解知道“函数依赖”是个什么东西。一下就是我的理解!

     函数依赖是关键码的推广,可以理解为属性之间存在的一种决定关系。


函数依赖

     举例:有一关系,学生(学号,姓名<不重复>,性别)

     每一个“学号”只能对应一个“姓名”,也就是一个“学号”对应一名同学,不能对应多名。这就是函数依赖!


局部依赖

     举例:学生(学号课程号,姓名<不重复>,成绩)

     在这个关系中,“学号”和“课程号”构成主键,非主属性是“姓名”和“成绩”。主键可以决定“姓名”,同时主键中的主属性“学号”也可以决定“姓名”。这就是局部依赖!


传递依赖

     举例:学生(学号,专业,宿舍地址<单属性>)

     在这个关系中,结合我们的生活,“学号”决定“专业”和“宿舍地址”,但“专业”不能决定“学号”,且“专业”也可以决定“宿舍地址”,那么“学号”与“宿舍地址”就形成了传递依赖!


多值依赖

     从字面上可以理解为,关系r的某个属性为多值属性,只要两个独立的1:N联系出现在一个关系中,就有可能形成多值依赖。


局部VS传递

     局部:主键和主属性都能决定非主属性

     传递:主键决定属性1,属性1决定属性2 (注意:属性1可为主或非主属性,属性2为非主)


小结

     局部、传递和传递依赖都有可能造成数据冗余和操作异常,所以我们要解决它们,如何解决?敬请期待下一篇《【DB】范式

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 7
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值