DB2中的MQT优化机制详解和实践
MQT :物化查询表。是以一次查询的结果为基础 定义创建的表(实表),以量取胜(特别是在百万,千万级别的量,效果更显著),可以更快的查询到我们需要的结果。MQT有两种类型,一种是系统维护的MQT ,一种是用户维护的MQT。本处是基于系统维护的MQT展开解析。
对于系统维护的MQT,这么和基表操作的数据更新。通过两种刷新机制:一种是即时刷新 refresh immediate ,另一种是延迟更新 refresh deferred 。
所谓的即时更新,就是当基表进行CRUD(增删改查)的操作时,对应的MQT表数据也会进行相应的刷新,这样的优点是能够保证MQT中的数据中是最新的,但是由于对基表进行操作的同时还要维护MQT表,负载有所增加。
使用延迟更新,当对基表进行操作的时候,MQT中的数据没有进行刷新,而是等到用户(DBA)阶段性的执行刷新命令(refresh table MQT_table)时才会进行刷新。这种方式适合用在绝大部分时间都是只读的应用系统中,或者数据的更新只发生维护窗口时间。
MQT刷新的方式还可以从数据的刷新范围进行分类,一是完全刷新,二是增量刷新。完全刷新是将基表中的所有数据重新进行计算和处理从而更新MQT数据。这种方式的缺点是当基表数据量大而且MQT定义复杂的时候,刷新过程会比较慢。增量更新方式是针对CRUD等操作更新过的数据的那一部分数据,对MQT中相应的数据进行刷新,而不需要访问及表中的所有数据。
结合起来,即时更新方式就是增量刷新方式,延迟刷新方式采用的是完全刷新,除了一种特殊的延迟刷新--->staging table 的延迟更新。当MQT的基表被修改时,变化就会传播进来,添加到staging table中,这样就利用staging table做增量刷新。当刷新操作完成时,staging table中的数据就会被删除。
即时刷新:
创建DB ,创建table
db2start
db2 => create db mydb
DB20000I CREATE DATABASE 命令成功完成。
db2 => connect to mydb
数据库连接信息
数据库服务器 = DB2/NT64 10.5.5
SQL 授权标识 = JOINT
本地数据库别名 = MYDB
db2 => create table dbtable(id int not null primary key,c int,d int,e int)
DB20000I SQL 命令成功完成。
db2 => insert into dbtable values(1,1,1,1),(2,2,2,2),(3,3,3,3),(4,4,4,4),(5,5,5,5)
DB20000I SQL 命令成功完成。
db2 => select * from dbtable
ID C D E
----------- ----------- ----------- -----------
1 1 1 1
2 2 2 2
3 3 3 3
4 4 4 4
5 5 5 5
5 条记录已选择。
db2 => insert into dbtable values(11,11,11,11),(12,12,12,12),(13,13,13,13),(14,14,41,41),(15,15,51,51)
DB20000I SQL 命令成功完成。
db2 => select * from dbtable
ID C D E
----------- ----------- ----------- -----------
1 1 1 1
2 2 2 2
3 3 3 3
4 4 4 4
5 5 5 5
11 11 11 11
12 12 12 12
13 13 13 13
14 14 41 41
15 15 51 51
10 条记录已选择。
创建MQT
db2 => create table mqttab as (select id,c,d,e from dbtable where id > 10) data initially deferred refresh immediate
DB20000I SQL 命令成功完成。
当前创建完毕之后,表里面还没有数据,查询为空。在操作一个基表
db2 => insert into dbtable values(111,111,111,11)
再次查询MQT 表就有数据了
db2 => select * from mqttab
ID C D E
----------- ----------- ----------- -----------
11 11 11 11
12 12 12 12
13 13 13 13
14 14 41 41
15 15 51 51
111 111 111 11
6 条记录已选择。
db2 => insert into dbtable values(121,222,222,1)
DB20000I SQL 命令成功完成。
db2 => select * from mqttab
ID C D E
----------- ----------- ----------- -----------
11 11 11 11
12 12 12 12
13 13 13 13
14 14 41 41
15 15 51 51
111 111 111 11
121 222 222 1
7 条记录已选择。
这就的即时的刷新。基表操作更新,MQT表即时进行更新。一下子操作两个表,负荷量较大。
延迟刷新
创建table
db2 => create table dbtable1(id int not null primary key,c int,d int,e int)
DB20000I SQL 命令成功完成。
db2 => insert into dbtable1 values(1,1,1,1),(2,2,2,2),(3,3,3,3),(4,4,4,4),(5,5,5,5)
DB20000I SQL 命令成功完成。
db2 => create table mqttab1 as (select id,c,d,e from dbtable1 where id > 10) data initially deferred refresh deferred
DB20000I SQL 命令成功完成。
创建完毕,插入基表数据。
db2 => insert into dbtable1 values(111,111,11,111)
mqt查询为空。
db2 => select * from mqttab1
ID C D E
----------- ----------- ----------- -----------
延迟刷新命令:
db2 => refresh table mqttabl
DB20000I SQL 命令成功完成。
db2 => select * from mqttabl
ID C D E
----------- ----------- ----------- -----------
111 111 11 111
1 条记录已选择。
就即时刷新和延迟刷新做了一个实例。不足请提出,共同进步!谢谢

DB2中的MQT优化机制详解和实践的更多相关文章
- Java中String对象创建机制详解()
一String 使用 private final char value来实现字符串存储 二Java中String的创建方法四种 三在深入了解String创建机制之前要先了解一个重要概念常量池Const ...
- JS中的函数节流throttle详解和优化
JS中的函数节流throttle详解和优化在前端开发中,有时会为页面绑定resize事件,或者为一个页面元素绑定拖拽事件(mousemove),这种事件有一个特点,在一个正常的操作中,有可能在一个短的 ...
- 浏览器 HTTP 协议缓存机制详解
最近在准备优化日志请求时遇到了一些令人疑惑的问题,比如为什么响应头里出现了两个 cache control.为什么明明设置了 no cache 却还是发请求,为什么多次访问时有时请求里带了 etag, ...
- JVM的垃圾回收机制详解和调优
JVM的垃圾回收机制详解和调优 gc即垃圾收集机制是指jvm用于释放那些不再使用的对象所占用的内存.java语言并不要求jvm有gc,也没有规定gc如何工作.不过常用的jvm都有gc,而且大多数gc都 ...
- 转 Java虚拟机5:Java垃圾回收(GC)机制详解
转 Java虚拟机5:Java垃圾回收(GC)机制详解 Java虚拟机5:Java垃圾回收(GC)机制详解 哪些内存需要回收? 哪些内存需要回收是垃圾回收机制第一个要考虑的问题,所谓“要回收的垃圾”无 ...
- [ 转载 ] Java开发中的23种设计模式详解(转)
Java开发中的23种设计模式详解(转) 设计模式(Design Patterns) ——可复用面向对象软件的基础 设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类 ...
- java面试题之----JVM架构和GC垃圾回收机制详解
JVM架构和GC垃圾回收机制详解 jvm,jre,jdk三者之间的关系 JRE (Java Run Environment):JRE包含了java底层的类库,该类库是由c/c++编写实现的 JDK ( ...
- Android应用AsyncTask处理机制详解及源码分析
1 背景 Android异步处理机制一直都是Android的一个核心,也是应用工程师面试的一个知识点.前面我们分析了Handler异步机制原理(不了解的可以阅读我的<Android异步消息处理机 ...
- 浏览器 HTTP 协议缓存机制详解--网络缓存决策机制流程图
1.缓存的分类 2.浏览器缓存机制详解 2.1 HTML Meta标签控制缓存 2.2 HTTP头信息控制缓存 2.2.1 浏览器请求流程 2.2.2 几个重要概念解释 3.用户行为与缓存 4.Ref ...
随机推荐
- linux脚本入门之终端显示输出
主要基本命令为 echo 与 printf. 关于echo: 其语法结构为:echo -选项参数 字符串: 例如:echo hello,world echo 'hello,world' echo ...
- ng 循环数据
显示数据的索引值 在ts中 public list:any[]=[ {title:"新闻1",},{title:"新闻2"},{title:"新闻3& ...
- JDK 1.8 之 Map.merge()
Map 中ConcurrentHashMap是线程安全的,但不是所有操作都是,例如get()之后再put()就不是了,这时使用merge()确保没有更新会丢失. 因为Map.merge()意味着我们可 ...
- .NET进阶篇-语言章-2-Delegate委托、Event事件
知识只有经过整理才能形成技能 整个章节分布简介请查看第一篇 内容目录 一.概述 二.解析委托知识点 1.委托本质 2.委托的使用 3.委托意义 逻辑解耦,减少重复代码 代码封装支持扩展 匿名方法和La ...
- CSS 选择符有哪些?哪些属性可以继承?优先级算法如何计算?
CSS 选择符有哪些? 1.id选择器(#id) 2.类选择器(.class) 3.标签选择器(div,h1,p) 4.相邻选择器(h1 + p) 5.子选择器(ul > li) 6.后代选择器 ...
- 初探内核之《Linux内核设计与实现》笔记上
内核简介 本篇简单介绍内核相关的基本概念. 主要内容: 单内核和微内核 内核版本号 1. 单内核和微内核 原理 优势 劣势 单内核 整个内核都在一个大内核地址空间上运行. 1. 简单.2. 高效 ...
- CSS3属性—— line-clamp控制文本行数
说明: 限制在一个块元素显示的文本的行数. -webkit-line-clamp 是一个 不规范的属性(unsupported WebKit property),它没有出现在 CSS 规范草案中. 为 ...
- bugku细心地大象
解压得到图片,查看属性,发现一段编码. 用winhex打开图片,发现头文件是错的,正常jpg文件头文件为FF D8 FF E0 说明不是图片,是zip的文件头,更换格式. 丢到kali用binwalk ...
- 并发新构件之CountDownLatch
CountDownLatch译为倒计时锁存器:JDK描述 :允许一个或多个线程等待直到在其他线程中执行的一组操作完成的同步辅助. A CountDownLatch用给定的计数初始化. awai ...
- Kotlin 中的伴生对象和静态成员
用了一段时间kotlin,越用越觉得好用,爱不释手啊,留点笔记. Kotlin 中,在类中定义的对象(object)声明,可使用 companion 修饰,这样此对象(object)就是伴生对象了.类 ...