数据库范式

数据库范式

标签:数据库

前置知识

唯一标识和区分数据记录的列或列组合。

empno ename deptno 其中empno就能唯一标示一行数据了,是码(empno=1的只有一行数据)

sno学号 cno课程号 grade分数 其中snocno两个才能唯一标示一行数据,snocno的组合属于码,其中单独一个不属于码(sno=1的可能不止一行数据,一个学生可以有多门课,cno=1的也可能不止一条数据,一门课可以被多个学生选,sno=1 and cno = 1的最多只能有一条)

主属性与非主属性

主属性:码中的列

非主属性:出了码中列之外的其他列

函数依赖关系

image.png

全部依赖

f(sno,cno)->grade

部分依赖

f(sno,cno)->dept,dept只依赖与sno(依赖与码中的部分)

传递依赖

f(sno,cno)->loc,通过sno就能知道dept,通过dept就能知道loc,所以通过sno能间接知道loc

范式的意义

  1. 消除冗余

  2. 消除增删改异常

    sno dept loc

    增:在没有学生之前,系与系地址就确定了,怎么存储这种关系

    删:学生全部删除了,系与系地址的关系也没了

    改:系地址变了,需要改该系所有同学的系地址(修改多行数据,修改的复杂性)

1NF

列的原子性

sno cno grade dept loc

2NF

不能有非主属性对主属性的部分函数依赖(一般存在主属性有多个的情况,比如sno and cno)

sno cno grade

sno dept loc

3NF

不能有非主属性对主属性的传递函数依赖关系(非主属性之间不能有函数依赖关系)

sno cno grade

sno dept

dept loc

BCNF

两种理解:

  1. 主属性之间不能有部分或传递函数依赖(主属性只有一个的时候不存在内部)
  2. 所有函数依赖关系x->y中,x一定是主属性(主属性只有一个的时候一定满足)

sno cno grade 两个主属性之间没有函数依赖关系

sno dept 只有一个主属性

dept loc 只有一个主属性

多值依赖

x->->y一个x能推导出多个y

4NF

4NF 非函数依赖范畴,是多值依赖范畴几遍满足BCNF也存在冗余与增删改异常

课程 老师 参考资料(一门课可以有多个老师带,一门课可以有多本参考资料)

拆成两张表

课程 老师

课程 参考资料

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值