
部分依赖:码是属性组,但其中部分属性就可以决定一些非码属性。2NF就是消除部分依赖:把这些非码属性和能够决定他们的码中的那些个属性拿出去单独成表。
如果是传递依赖:非码属性中存在依赖(这样这个表就起码两层依赖了)。3NF就是消除传递依赖:把非码属性中(A依赖B)这两个属性拿出去单独成表,主表中A去掉。
1、传递函数依赖
设X,Y,Z是关系R中互不相同的属性集合,存在X→Y(Y !→X),Y→Z,则称Z传递函数依赖于X。
2、完全函数依赖
设X,Y是关系R的两个属性集合,X’是X的真子集,存在X→Y,但对每一个X’都有X’!→Y,则称Y完全函数依赖于X。
3、部分函数依赖
设X,Y是关系R的两个属性集合,存在X→Y,若X’是X的真子集,存在X’→Y,则称Y部分函数依赖于X。
扩展资料所谓函数依赖是指关系中一个或一组属性的值可以决定其它属性的值。函数依赖正象一个函数 y = f(x) 一样,x的值给定后,y的值也就唯一地确定了。
如果属性集合Y中每个属性的值构成的集合唯一地决定了属性集合X中每个属性的值构成的集合,则属性集合X函数依赖于属性集合Y,计为:Y→X。属性集合Y中的属性有时也称作函数依赖Y→X的决定因素(determinant)。例:身份z号→姓名。
参考资料来源:百度百科-完全函数依赖
百度百科-部分函数依赖
百度百科-传递函数依赖
你好!第一范式的定义:每一个分量都是不可分的数据项。
因此只要满足每一个属性是不可分的数据项就是第一范式,就算有部分函数依赖也一样的,是可以有部分函数依赖的。
下面给出范式简单的定义:
1NF:每个分量都必须是不可分的数据项。
2NF:满足1NF,每个非主属性对码都是完全函数依赖,排除了部分函数依赖。
3NF:满足1NF,每个非主属性都不传递依赖于码,排除了传递函数依赖。
BCNF:满足1NF,每个决定因素都包含码,且消除了主属性对码的部分与传递函数依赖。
4NF:满足1NF,删除同一表内的多对多关系。消除了非平凡且非函数依赖的多值依赖。4NF所允许的非平凡的多值依赖实际上是函数依赖。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)