1、反规范的好处 
是否规范化的程度越高越好?这要根据需要来决定,因为“分离”越深,产生的关系越多,关系过多,连接操作越频繁,而连接操作是最费时间的,特别对以查询为主的数据库应用来说,频繁的连接会影响查询速度。所以,关系有时故意保留成非规范化的,或者规范化以后又反规范了,这样做通常是为了改进性能。 
例如帐户系统中的“帐户”表B-TB01,它的列busi-balance(企业帐户的总余额)就违反规范,其中的值可以通过下面的查询获得: 
select busi-code,sum(acc-balance) 
from B-TB06 
group by busi-code 
如果B-TB01中没有该列,若想获得busi-name(企业名称)和企业帐户的总余额,则需要做连接操作: 
select busi-name,sum(acc-balance) 
from B-TB01,B-TB06 
where B-TB01.busi-code=B-TB06.busi-code 
group by busi-code 
如果经常做这种查询,则就有必要在B-TB01中加入列busi-balance,相应的代价则是必须在表B-TB06上创建增、删、改的触发器来维护B-TB01表上busi-balance列的值。类似的情况在决策支持系统中经常发生。 
反规范的好处是降低连接操作的需求、降低外码和索引的数目,还可能减少表的数目,相应带来的问题是可能出现数据的完整性问题。加快查询速度,但会降低修改速度。因此决定做反规范时,一定要权衡利弊,仔细分析应用的数据存取需求和实际的性能特点,好的索引和其它方法经常能够解决性能问题,而不必采用反规范这种方法。 
2、常用的反规范技术 
在进行反规范操作之前,要充分考虑数据的存取需求、常用表的大小、一些特殊的计算(例如合计)、数据的物理存储位置等。常用的反规范技术有增加冗余列、增加派生列、重新组表和分割表。 
(1)增加冗余列是指在多个表中具有相同的列,它常用来在查询时避免连接操作。例如前面例子中,如果经常检索一门课的任课教师姓名,则需要做class和teacher表的连接查询: 
select class-name,teacher-name 
from class,teacher 
where class.teacher-no=teacher.teacher-no 
这样的话就可以在class表中增加一列teacher-name就不需要连接操作了。 
增加冗余列可以在查询时避免连接操作,但它需要更多的磁盘空间,同时增加表维护的工作量。 
(2)增加派生列指增加的列来自其它表中的数据,由它们计算生成。它的作用是在查询时减少连接操作,避免使用集函数。例如前面所讲的账户系统中的表B-TB01的列busi-balance就是派生列。派生列也具有与冗余列同样的缺点。 
(3)重新组表指如果许多用户需要查看两个表连接出来的结果数据,则把这两个表重新组成一个表来减少连接而提高性能。例如,用户经常需要同时查看课程号,课程名称,任课教师号,任课教师姓名,则可把表class(class-no,class-name,teacher-no)和表teacher(teacher-no,teacher-name)合并成一个表class(class-no,class-name,teacher-no,teacher-name)。这样可提高性能,但需要更多的磁盘空间,同时也损失了数据在概念上的独立性。 
(4)有时对表做分割可以提高性能。表分割有两种方式: 
1水平分割:根据一列或多列数据的值把数据行放到两个独立的表中。 
水平分割通常在下面的情况下使用。 
·表很大,分割后可以降低在查询时需要读的数据和索引的页数,同时也降低了索引的层数,提高查询速度。 
·表中的数据本来就有独立性,例如表中分别记录各个地区的数据或不同时期的数据,特别是有些数据常用,而另外一些数据不常用。 
·需要把数据存放到多个介质上。 
例如法规表law就可以分成两个表active-law和inactive-law。activea-authors表中的内容是正生效的法规,是经常使用的,而inactive-law表则使已经作废的法规,不常被查询。 
水平分割会给应用增加复杂度,它通常在查询时需要多个表名,查询所有数据需要union操作。在许多数据库应用中,这种复杂性会超过它带来的优点,因为只要索引关键字不大,则在索引用于查询时,表中增加两到三倍数据量,查询时也就增加读一个索引层的磁盘次数。 
2垂直分割:把主码和一些列放到一个表,然后把主码和另外的列放到另一个表中。 
如果一个表中某些列常用,而另外一些列不常用,则可以采用垂直分割,另外垂直分割可以使得数据行变小,一个数据页就能存放更多的数据,在查询时就会减少I/O次数。其缺点是需要管理冗余列,查询所有数据需要join操作。 
3、反规范技术需要维护数据的完整性 
无论使用何种反规范技术,都需要一定的管理来维护数据的完整性,常用的方法是批处理维护、应用逻辑和触发器。 
批处理维护是指对复制列或派生列的修改积累一定的时间后,运行一批处理作业或存储过程对复制或派生列进行修改,这只能在对实时性要求不高的情况下使用。 
数据的完整性也可由应用逻辑来实现,这就要求必须在同一事务中对所有涉及的表进行增、删、改操作。用应用逻辑来实现数据的完整性风险较大,因为同一逻辑必须在所有的应用中使用和维护,容易遗漏,特别是在需求变化时,不易于维护。 
另一种方式就是使用触发器,对数据的任何修改立即触发对复制列或派生列的相应修改。触发器是实时的,而且相应的处理逻辑只在一个地方出现,易于维护。一般来说,是解决这类问题的最好的办法。

数据库设计之反规范化相关推荐

  1. 数据库安全-分布式数据库-数据仓库技术-反规范化技术-大数据

    继续肝吧,本章主要讲的数据库安全,分布式数据库,数据仓库技术,反规范化技术,大数据,概念性的东西比较多. 1.数据库安全 考的不多,了解下补充自己的知识. 静态转储:即冷备份,指在转储期间不允许对数据 ...

  2. MYSQL中什么是规范化_数据库设计 - 什么是规范化(或规范化)?

    规范化基本上是设计数据库模式,以避免重复和冗余数据. 如果某些数据在数据库中的多个位置重复,则存在在一个位置而不是另一个位置更新的风险,从而导致数据损坏. 从正常形式到正常形式有许多归一化水平. 每种 ...

  3. 数据库设计中关系规范化理论总结

    写在前面:大家好K.首先为你点进这篇有趣的文章点赞

  4. 数据库设计规范化的5个要求

    通常情况下,可以从两个方面来判断数据库是否设计的比较规范.一是看看是否拥有大量的窄表,二是宽表的数量是否足够的少.若符合这两个条件,则可以说明这个数据库的规范化水平还是比较高的. 当然这是两个泛泛而谈 ...

  5. 第4章 数据库设计---数据库原理及应用

    目录 一.数据库设计方案 1. 数据库应用架构设计:单用户.集中.CS.分布 2. 数据库结构设计:概念.逻辑.物理 3. 数据库应用访问方式设计:访问方式 数据库结构设计模型 概念数据模型:概念,不 ...

  6. 数据库设计五要点 让数据库设计更加规范

    通常情况下,可以从两个方面来判断数据库是否设计的比较规范.一是看看是否拥有大量的窄表,二是宽表的数量是否足够的少.若符合这两个条件,则可以说明这个数据库的规范化水平还是比较高的.当然这是两个泛泛而谈的 ...

  7. 数据库设计之规范化和反规范化

    文章目录 一.规范化 二.反规范化 数据库设计的规范化能够经常被提及,但是反规范化很少被涉猎.实际应用中反规范化应用的场景很多.本文主要介绍一下数据库的反规范化. 一.规范化 常见的规范化有数据库设计 ...

  8. 数据库设计-规范化规则

    SQL反模式一书在附录章节给出了设计关系数据库的规范化规则,一个简明的规范化规则清单. 关系是什么 在规范化之前,我们先要理解下关系. 数学中关系定义:两个不同数据域上的值的集合,通过一个条件得到的一 ...

  9. 数据库设计之范式与反范式

    范式设计 什么是范式? 范式来自英文Normal Form,简称NF.要想表之间设计-个好的关系,必须使关系 满足一定的约束条件,此约束已经形成了规范,分成几个等级,一级比一级要求 得严格.满足这些规 ...

最新文章

  1. 21 Merge Two Sorted Lists(两链表归并排序Easy)
  2. GO恶意样本实例分析
  3. Qt文档阅读笔记-Qt4 Lower-Level API扩展Qt Applications(Qt4中Plugin的使用)解析与实例
  4. Spark学习-SparkSQL--01-SparkSQL CLI
  5. 【Java从0到架构师】MyBatis - 增删改、动态 SQL
  6. 震惊!雷军表示要出千元5G手机!
  7. python微软产品一般都一个25位的序列号_Python易错点6
  8. 多线程之同步Synchronized
  9. 采集屏幕编码H264
  10. 【阿帕奇服务器文件修改后页面不发生变化问题解决】
  11. “尝鲜”元宇宙,周杰伦最佳拍档方文山将于7月25日官宣《华流元宇宙》
  12. java 版剑指offer算法集锦
  13. 如何下载GitHub网站上的代码的方法(未完,更新中。。。)
  14. 对币圈假冒科学家骗子盗取私钥的分析
  15. html5游戏 很费流量嘛,2017TFC5玩游戏林勇坤 优化HTML5游戏流量数据转化
  16. 牛客:毕业生的纪念礼物(优先队列 || STL嵌套)
  17. 七巧板涂色算法(Python)
  18. switch日版有中文吗_原神switch日版和港版能不能玩 用日版NS能玩原神吗
  19. 使用JMeter模拟多IP发送请求(IP欺骗)
  20. 经典iframe后台系统框架

热门文章

  1. 入侵检测三级跳 解析跳板技术
  2. 康奈尔大学做笔记方法,让效率提高100%@
  3. ECMAScript 6(5)字符串与Unicode编码大于65535的字符
  4. 维克客户管理软件 v1.26 通用版 免费
  5. 计算机与教育技术学的关系,信息技术和现代教育技术的关系
  6. DSIN 深度 Session 兴趣网络介绍及源码剖析
  7. linux安装Promethus普罗米修斯监控
  8. Linux 安装docker,以及docker的基本操作
  9. 业界 | 机器学习+ICU:为重症患者提供实时护理
  10. 洛谷 1948 笨笨的电话网络