数据库1NF,2NF,3NF,BCNF总结

上述几个范式的定义自己曾理解了很多遍,但总是容易忘记,决定写个总结,忘了就来看看。

1NF:通俗的将是表的每一列(数据项)都是不可再分的一部分

2NF:在1NF的基础上,所有非主属性对码完全函数依赖(这里完全函数依赖主要区别于平凡函数依赖,是平凡函数依赖的一个子集,平凡函数依赖可以理解为一个关系模式上的属性集X可以完全确定属性集Y,而完全函数依赖则是更细一步规定了X的子集不能完全确定属性集Y)

3NF:在2NF的基础上,消除了非主属性对对码的传递依赖(传递依赖即X->Y,Y!->X,Y->Z,且Z不属于Y,则称Z对X传递依赖)

BCNF:在3NF的基础上,消除了主属性对码的部分函数依赖和传递函数依赖,通俗的将就是在关系模式中每一个决定因素都包含候选键,也就是说,只要属性或属性组A能够决定任何一个属性B,则A的子集中必须有候选键。

你可能感兴趣的:(数据库1NF,2NF,3NF,BCNF总结)