数据库三大范式

常见数据库设计范式包括:第一范式,第二范式,第三范式及BC范式,当然还有第四及第五范式不过这里我们会把重点放到前三个范式上,这也是目前我们大多数数据库设计所要遵循的范式。

数据操作异常及数据冗余

在这里插入图片描述

数据冗余

是指相同的数据在多个地方存在,或者说表中的某个列可以由其它列计算得到,这样就说表中存在着数据冗余。

第一范式(1NF)

定义:数据库表中的所有字段都是单一属性,不可再分的。
这个单一属性是由基本的数据类型所构成的,如整数、浮点数、字符串等。换句话说第一范式要求数据库中的表都是二维表
在这里插入图片描述
第二范式(2NF)

定义:数据库的表中不存在非关键字段对任一候选关键字段的部分函数依赖。
部分函数依赖是指存在着组合关键字中的某一关键字决定非关键字的情况。
换句话说:所有单关键字段的表都符合每二范式。
在这里插入图片描述
由于供应商和商品之间是多对多的关系,所以只有使用商品名称和供应商名称才可以唯一标识出一件商品。也就是商品名称和供应商名称是一组组合关键字。上表中存在以下的部份函数依赖关系
(商品名称)->(价格,描述,重量,商品有效期)
(供应商名称)-> (供应商电话)

存在的问题:
1.插入异常
2.删除异常
3.更新异常
4.数据冗余

解决:
在这里插入图片描述
第三范式(3NF)

定义:第三范式是在第二范式的基础之上定义的,如果数据表中不存在非关键字段,对任意候选关键字段的传递函数依赖则符合第三范式。

在这里插入图片描述
存在以下转递函数依赖关系:
(商品名称)-> (分类)-> (分类描述)
也就是说存在非关键字段“分类描述"
对关键字段“商品名称”的传递函数依赖

存在问题:
(分类,分类描述) 对于每一个商品都会进行记录,所以存在着数据冗余。同时也还存在数据的插入,更新及删除异常。
在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值