第六章——>模式分解

在某个数据库中,有关系模式sc(sno,iname,ilocal,cno,ctitle,grade)其中sno为学号,iname为教师名,ilocal为教师住址,cno为课程号,ctitle为课程名,grade为成绩。
有以下语义:
1)每个学生可以选修多门课程,每门课程可以有多名学生选修,每个学生选修一门课程获得一个成绩
2)每个教师有唯一的一个住址
3)每门课程有唯一课程号
4)每个教师可以讲授多门课程,每门课程可以有多名教师讲授
请完成以下问题:
1) 分析语义,给出函数依赖
2) 分析范式类型
3) 举例说明存在哪些数据异常现象
4) 将其分解为更高一级范式
解答:
1)
F={(sno,cno)->grade,iname->ilocal,cno->ctitle}
2)
确定候选码:(sno,cno,iname)
显然非主属性grade 、ilocal、ctitle都是部分依赖于候选码,因此,次关系模式是1NF。
3)
a.数据冗余:ilocal、ctitle都会冗余存储;
b.插入异常,如果有新增加的学生、老师、课程,都会因为没有选课信息而无法插入;
c.删除异常,如果存在某老师只带了一门课,假设该课只有一个学生选修,因为人数太少,教务处停开该课,则删除该选课记录,就会导致这名老师的信息丢失;
d.当然也存在更新困难的问题。
4)
为消除部分函数依赖,可以4个关系模式(sno,cno,grade);(iname,ilocal);(cno, ctitle);(iname,cno);这样就可以消除部分函数依赖、传递依赖,达到更高级的范式。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值