数据库范式

  • 1NF:表中的每个字段只能包含一种数据类,每个数据只在一个地方保存。1NF也称原子数据要求,即每个字段是不可分割的,象原子一样。1NF告诉我们一个字段中不要放多个数据。
    破坏1NF的情况:
         1、一个字段中堆放相关数据。如供应商字段即放供应商名又放供应商地址。应分解为多个字段。
         2、重复字段。如订单表中有这些字段商品编号1,数量1,商品编号2,数量2,商品编号3,数量3,等等。
  • 2NF:在1NF的基础上,包含一个且只有一个实体的数据。不能有嵌套实体。或者说每个非键列都依赖于全键列,没有不完全相关,要完全相关。
  • 3NF:在2NF的基础上,所有非键列应直接依赖于主键列,而不是其他非键列如计算字段。或者说每个表只包含一件事的信息,不要包含多个事实的信息。
  • BDNF:每个非键列都要依赖于整个主关键字,而不是部分主关键字。(3NF说的是这句话的前半部分,BDNF说的是这句话的后半部分)
  • 4NF:一组相关实体之间存在相关性时,要将这种关系确切表示出来,而不要隐含与一个表中。如一个表中隐含有某种关系,应将这种关系用一个表明确表示出来。
  • 5NF:分解为两个表会丢失信息,但可以分解为多个表而不会丢失信息。如果不符合前面几个范式时,都是将一个表分解为两个表。

正规化的最终结果是:当更新表中的一项数据时,一次只影响表中的一行,不能影响多行,同时,只修改这行中的一个字段时,也不能影响这行中的其他字段。当某一个原子数据需要改变时,要修改多个表中的多行、一个表中的多行或一行中的多个字段,就表明没有正规化彻底。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值