关系数据库范式

函数依赖

函数Y=f(x):给定一个x值,都会有一个y值与之对应
关系数据库中讨论函数依赖更注重语义上的关系:
省=f(城市)
在这里插入图片描述
关于平凡函数依赖与非平凡函数依赖
在这里插入图片描述
完全函数依赖与部分函数依赖
在这里插入图片描述
传递依赖
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
有关系模式:学生(学号,姓名,性别,身份证号,年龄,所在系)

  • 候选码:学号,身份证号
  • 主码:学号或身份证号
  • 主属性:学号,身份证号
  • 非主属性:姓名,性别,年龄,所在系

例子:教师_课程(教师号,课程号,授课学年)找出候选码
语义:一个教师在一个学年可以讲授多门课程,而且一门课程在一个学年也可以由多个教师讲授,同一个学年可以开设多门课程

候选码(教师号,课程号,授课学年)全码表

第二范式

在这里插入图片描述
分解办法:

  • 首先,对于组成主码的属性集合的每一个子集,用它作为主码构成一个表
  • 然后,将完全函数依赖于这些主码的属性放置到相应的表中
  • 最后,去掉只由主码的真子集构成的表

S_L_C(Sno,Sname,Ssex,Sdept,Sloc,Cno,Grade)
Sno->Sname,Sno->Ssex,Sno->Sdept,Sno->Sloc,(Sno,Cno)->Grade,Sdept->Sloc
码(Sno,Cno)因为存在(Sno,Cno)->Sdept等多个部分函数依赖,所以不是2NF

  1. 分解表
    S-L(Sno,Sloc…)
    C(Cno,…)
    S-C(Sno,Cno…)
  2. 将完全函数依赖于这些主码的属性放置到相应表中
    S-L(Sno,Sname,Ssex,Sdept,Sloc)
    C(Cno)
    S-C(Sno,Cno,Grade)
  3. 最后,去掉只由主码的真子集构成的表,最终分解为
    S-L(Sno,Sname,Ssex,Sdept,Sloc)
    S-C(Sno,Cno,Grade)
    注意,去掉只由主码的真子集构成的表
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值