第二范式(2NF)
来源:互联网 发布:java获取网站数据 编辑:程序博客网 时间:2024/04/30 02:30
第二范式(2NF):如果关系模式R(U,F)中的所有非主属性都完全依赖于任意一个候选关键字,则称关系R 是属于第二范式的。
例:选课关系 SCI(SNO,CNO,GRADE,CREDIT)其中SNO为学号, CNO为课程号,GRADEGE 为成绩,CREDIT 为学分。 由以上条件,关键字为组合关键字(SNO,CNO)
在应用中使用以上关系模式有以下问题:
a.数据冗余,假设同一门课由40个学生选修,学分就 重复40次。
b.更新异常,若调整了某课程的学分,相应的元组CREDIT值都要更新,有可能会出现同一门课学分不同。
c.插入异常,如计划开新课,由于没人选修,没有学号关键字,只能等有人选修才能把课程和学分存入。
d.删除异常,若学生已经结业,从当前数据库删除选修记录。某些门课程新生尚未选修,则此门课程及学分记录无法保存。
原因:非关键字属性CREDIT仅函数依赖于CNO,也就是CREDIT部分依赖组合关键字(SNO,CNO)而不是完全依赖。
解决方法:分成两个关系模式 SC1(SNO,CNO,GRADE),C2(CNO,CREDIT)。新关系包括两个关系模式,它们之间通过SC1中的外关键字CNO相联系,需要时再进行自然联接,恢复了原来的关系
- 第二范式(2NF)
- 第二范式(2NF)
- 数据库 - 第二范式(2NF)
- 对第一范式(1NF) 第二范式(2NF) 第三范式(3NF)的理解
- 数据库范式(1NF 2NF 3NF BCNF)
- 数据库范式(1NF 2NF 3NF BCNF)
- 数据库范式(1NF 2NF 3NF BCNF)
- 数据库范式(1NF 2NF 3NF BCNF)
- 数据库范式(1NF 2NF 3NF BCNF)
- 数据库范式(1NF 2NF 3NF BCNF)
- 数据库范式(1NF;2NF;3NF;BCNF)
- 数据库范式(1NF;2NF;3NF,BCNF)
- 数据库范式(1NF 2NF 3NF BCNF)
- 数据库范式(1NF 2NF 3NF BCNF)
- 数据库范式(1NF 2NF 3NF BCNF)
- 数据库范式(1NF 2NF 3NF BCNF)
- 数据库范式(1NF 2NF 3NF BCNF)
- 数据库范式(1NF 2NF 3NF BCNF)
- C++ 学习之构造函数:构造函数小结3 默认构造函数、隐式类型转换和复制构造函数
- 图示
- 第一范式(1NF)
- SPDY
- away3d 正立方体旋转,鼠标悬停停止旋转,鼠标离开继续旋转,点击某个面,打开新页面。
- 第二范式(2NF)
- Configuring Fedora Linux Remote Access using SSH
- android工程导入错误
- 【转】PHP设计模式漫谈
- 关于浅拷贝
- 第三范式(3NF)
- sqlserver sql语句|经典sql语句|实用sql语句
- erlang的几个目录操作命令
- C语言里的结构体和联合体