前往小程序,Get更优阅读体验!
立即前往
发布
社区首页 >专栏 >数据库范式

数据库范式

作者头像
九转成圣
发布2024-04-10 16:51:46
发布2024-04-10 16:51:46
1480
举报
文章被收录于专栏:csdncsdn

数据库范式

标签:数据库

前置知识

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

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

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

主属性与非主属性

主属性:码中的列

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

函数依赖关系

全部依赖

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也存在冗余与增删改异常

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

拆成两张表

课程 老师

课程 参考资料

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-03-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 数据库范式
    • 标签:数据库
  • 前置知识
    • 主属性与非主属性
    • 函数依赖关系
      • 全部依赖
      • 部分依赖
      • 传递依赖
  • 范式的意义
  • 1NF
  • 2NF
  • 3NF
  • BCNF
  • 多值依赖
  • 4NF
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档