常见数据库设计范式包括:第一范式,第二范式,第三范式及BC范式,当然还有第四及第五范式不过这里我们会把重点放到前三个范式上,这也是目前我们大多数数据库设计所要遵循的范式。
数据操作异常及数据冗余
数据冗余
是指相同的数据在多个地方存在,或者说表中的某个列可以由其它列计算得到,这样就说表中存在着数据冗余。
第一范式(1NF)
定义:数据库表中的所有字段都是单一属性,不可再分的。
这个单一属性是由基本的数据类型所构成的,如整数、浮点数、字符串等。换句话说第一范式要求数据库中的表都是二维表。
第二范式(2NF)
定义:数据库的表中不存在非关键字段对任一候选关键字段的部分函数依赖。
部分函数依赖是指存在着组合关键字中的某一关键字决定非关键字的情况。
换句话说:所有单关键字段的表都符合每二范式。
由于供应商和商品之间是多对多的关系,所以只有使用商品名称和供应商名称才可以唯一标识出一件商品。也就是商品名称和供应商名称是一组组合关键字。上表中存在以下的部份函数依赖关系
(商品名称)->(价格,描述,重量,商品有效期)
(供应商名称)-> (供应商电话)
存在的问题:
1.插入异常
2.删除异常
3.更新异常
4.数据冗余
解决:
第三范式(3NF)
定义:第三范式是在第二范式的基础之上定义的,如果数据表中不存在非关键字段,对任意候选关键字段的传递函数依赖则符合第三范式。
存在以下转递函数依赖关系:
(商品名称)-> (分类)-> (分类描述)
也就是说存在非关键字段“分类描述"
对关键字段“商品名称”的传递函数依赖
存在问题:
(分类,分类描述) 对于每一个商品都会进行记录,所以存在着数据冗余。同时也还存在数据的插入,更新及删除异常。