数据库基础(3)--范式

第一范式:E-R模型允许实体集和联系集的属性具有某些程度的子结构。比如address属性下,拥有子属性street,city,state等。如果一个属性的元素被认为是不可分的,则我们认为这个属性是原子的。如果一个关系模式R中,所有的属性都是原子的,不可再分的,则称该关系模式R属于第一范式(1NF)。

第二范式:如果关系模式r®中,属性集合R中的每个属性A都满足如何准则之一:
(1)它出现在一个候选码中;
(2)他它没有部分依赖于一个候选码;

判断一个关系模式是否属于第二范式可以根据以下步骤来判断:
(1)找出所有的码;
(2)根据第一步找出的码,找出所有的主属性;
(3)数据表中,去除所有的主属性,剩下的就是非主属性;
(4)查看是否存在非主属性对主码的部分函数依赖。

如下表,dept-name和budget都可以唯一确定一个元组。所以dept-name和budget都是候选码。主属性即:dept-name和budget。非主属性:building。因为dept-name和budget都是单个元素的候选码,其真子集为空,所以不存在building对两个候选码的函数依赖。所以是第二范式。
表1
第三范式:在第二范式的基础上,不存在传递依赖。
所以判断一个关系模式是不是第三范式,可以根据以下步骤来进行:
(1)先判断是不是第二范式;
(2)在确定是第二范式的基础上,看有没有传递依赖,如果有的话,不是第三范式。
如果没有的话,是第三范式。

如下表:关系模式中ID,name,salary这三个属性中都没有重复的,都可以唯一确定一个元组。他们三个都是包含单个属性的候选码,真子集为空。所以不存在非主属性对候选码的部分依赖。由此判断这个关系模式是第二范式。但是我们可以看到存在函数依赖ID-dept_name,depet_name-building,ID-building,存在传递依赖。所以它不是第三范式。

表二

第一,二,三范式的区别:
(1)第二范式消除了第一范式中非主属性对候选码的部分函数依赖;
(2)第三范式消除了第二范式中的传递依赖。

加油!!!

本文部分参阅了https://www.zhihu.com/question/24696366,感谢!

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值