学习Dot NET

导航

复习基础知识:数据规范化

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

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

posted on 2004-05-09 09:51  学习.NET  阅读(1322)  评论(0编辑  收藏  举报