数据库范式(1NF、2NF、3NF、BCNF)

  • Post author:
  • Post category:其他


1NF


定义:关系中每一分量不可再分。即不能以集合、序列等 作为属性值。

注意:

分量是否需要再分,与具体应用有关。如果用到


值的一部分,则需要进一步分割 。

2NF


定义:若R为1NF,且每个非主属性完全依赖于码,则 R为2NF。


非主属性有两种,一种完全依赖于码,一种部分依赖于码。 若要得到2NF,则需要消除非主属性对码的部分依赖 。


3NF


定义:关系模式R< U , F >中,若不存在这样的码X,属性组Y及非主属性Z(Z Y),使得下式成立


, 则称R属于3NF。

若要获得3NF,则

需要消除非主属性对码的传递依赖。


BCNF


定义:关系模式R< U , F >中,对于属性组X,Y,若X->Y 且Y 不属于X时X必含有码,则R< U , F > 属于BCNF。



各个范式之间的关系如图所示:




版权声明:本文为qq_52897257原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。