三大范式
1. 概念理解
1.函数依赖:如果通过A属性(属性组),可以确定唯一B属性的值,那么B依赖于A。比如上图的姓名,完全依赖于学号
2.完全函数依赖:如果A是一个属性组,则B属性值的确定需要依赖于A属性组中的所有的属性值。属性组是指多个字段,那么比如我们要想知道一个分数,就必须依赖于学号和课程名称两个属性才能确定一个分数,其他的属性是不能确定某一个分数的
3.部分函数依赖:如果A是一个属性组,则B属性值的确定需要依赖A属性组的某一些字段即可,例如学号和课程名称为一个属性组,那么学生姓名其实就只需要学号就可以确定
4.传递函数依赖:如果A属性(属性组),可以确定唯一个B属性的值,再通过B属性的值又可以唯一确定C属性的值,例如一个学号确定一个系名,一个系名对应一个系主任
5.主键:在一张表中,一个属性或者属性组,被其他所有属性完全依赖,则称这个属性为该码的表,比如上图的学号和课程名称组成的属性组
2. 第一范式
每列不可再分
3. 第二范式
消除非主键对主键的部分函数依赖,即表中任意一个主键或任意一组联合主键,可以确定除该主键外的所有的非主键值。
部分函数依赖: (A,B)-> C 且 B -> C 主键的一部分即可确定一列,违反了第二范式,分表
3. 第三范式
在第二范式的基础上消除传递依赖 即
(A,B) -> C
(A,B) -> D
C -> D
违反了第三范式,分表

浙公网安备 33010602011771号