1NF:一个table中的列是不可再分的(即列的原子性)
官方定义:第一范式(1NF):数据库表中的字段都是单一属性的,不可再分。
注:只要是关系数据库都满足第一范式。
2NF:一个table中的行是可以唯一标示的,(即table中的行是不可以有重复的)
官方定义:第二范式(2NF):数据库表中不存在非关键字段对任一候选关键字段的部分函数依赖。
3NF:一个table中列不依赖以另一个table中的非主键的列,还是不通俗!巨寒!!
官方定义:第三范式(3NF):在第二范式的基础上,数据表中如果不存在非关键字段对任一候选关键字段的传递函数依赖则符合第三范 式。
举个例子吧:有一个部门的table,我们叫它tbl_department, 它有这么几列(dept_id(pk),dept_name,dept_memo...)
有一个员工table,我们叫它tbl_employee,在这个table中有一列dept_id(fk)描述关于部门的信息,
若tbl_employee要满足3NF,则在tbl_employee中就不得再有除dept_id列的其它有关部门信息的列!
一般数据库的设计满足3NF即可!
BCNF:通常认为BCNF是修正的第三范式,它比3NF又进一步!
4NF:
5NF:将一个table尽可能的分割成小的块,以排除在table中所有冗余的数据
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/xiehua1234/archive/2010/10/22/5959772.aspx