DB2的物化视图MQT是基于查询结果定义的一个表,MQT中包括的数据来自MQT定义所基于的一个或多个表, 使用MQT能够显著提高查询的操作性能。

数据库的视图和MQT都是基于一个查询来定义的。每当视图被引用时,视图所基于的查询便会运行。

但MQT实际上会将查询结果存储为数据,您能够使用MQT中的这些数据。而不是使用底层表中的数据。

MQT 能够显著提高查询的性能,尤其是提高复杂查询的性能。

假设优化器确定查询或查询的一部分能够用一个 MQT 来解决,那么查询就能够被重写以便利用 MQT。

MQT 能够在创建表时定义。能够定义为由系统维护,也能够定义为由用户维护。

DATA INITIALLY DEFERRED 子句的意思是。在运行 CREATE TABLE 语句的时候,并不将数据插入到表中。
MQT 被创建好之后,就会处于检查暂挂(check pending)状态,在对它运行 SET INTEGRITY 语句之前。不能查询它。IMMEDIATE CHECKED 子句指定。必须依据用于定义该 MQT 的查询对数据进行检查,并刷新数据。

NOT INCREMENTAL 子句指定对整个表进行完整性检查。

这样的 MQT 中的数据是由系统维护的。

当创建这样的类型的 MQT 时,能够指定表数据是 REFRESH IMMEDIATE 还是 REFRESH DEFERRED。通过 REFRESH keyword能够指定怎样维护数据。DEFERRED 的意思是,表中的数据能够在不论什么时候通过 REFRESH TABLE 语句来刷新。

系统维护的 MQT,无论是 REFRESH DEFERRED 类型的还是 REFRESH IMMEDIATE 类型的,对它们的插入、更新或删除操作都是不同意的。可是。对于 REFRESH IMMEDIATE 类型的系统维护的 MQT,能够通过 对底层表的更改(即插入、更新或删除操作)来更新。

以下看一个样例

首先创建原始表

CREATE TABLE T (
ID INTEGER NOT NULL,
COL1 VARCHAR(128),
COL2 VARCHAR(128),
COL3 VARCHAR(128),
COL4 VARCHAR(128),
COL5 VARCHAR(128),
PRIMARY KEY (ID)
) ORGANIZE BY ROW;

创建MQT表

CREATE TABLE T_MQT ( ID, COL1, COL2, COL3 )
AS ( select ID, COL1, COL2, COL3 from T )
DATA INITIALLY DEFERRED REFRESH IMMEDIATE MAINTAINED BY SYSTEM;
SET INTEGRITY FOR T_MQT IMMEDIATE CHECKED FULL ACCESS;

写入数据到原始表中

insert into T(ID, COL1, COL2, COL3, COL4, COL5) values (1, 'col1', 'col2', 'col3', 'col4', 'col5');
insert into T(ID, COL1, COL2, COL3, COL4, COL5) values (2, 'col1', 'col2', 'col3', 'col4', 'col5');

查询原始表和MQT表。会发如今MQT表里也有数据了

select * from T;
select * from T_MQT;

原文链接:

p=160" target="_blank">DB2物化视图(Materialized Query Tables, MQT)

最新文章

  1. 活用shape、selector和layer-list来打造自己想要的背景效果
  2. 博客代码:iframe—网页中嵌入其他网页
  3. Native wifi API使用
  4. TI的DSP、ST的ARM、Intel的X86浮点性能对比
  5. 游标、动态sql、异常
  6. [转载] tmux 使用指南
  7. hdu 4614 Vases and Flowers
  8. CentOS安装某个命令的办法如locate
  9. C# winform 登录 单例模式(转)
  10. activity-intent-startActivity-startActivityResult
  11. EXPDP和IMPDP简单测试
  12. Scala学习---映射和元祖
  13. solr学习-基础环境搭建(一)
  14. java的优势解读
  15. ffmpeg结构体以及函数介绍(一)
  16. 「LOJ 2289」「THUWC 2017」在美妙的数学王国中畅游——LCT&泰勒展开
  17. 实战web前端之:Bootstrap框架windows下安装与使用
  18. RestTemplate的使用介绍汇总
  19. 阿里云ECS Ubuntu16.0 安装 uwsgi 失败解决方案
  20. c++沉思录 学习笔记 第五章 代理类

热门文章

  1. 可变对象 vs 不可变对象(Python)
  2. 比起 Windows,怎样解读 Linux 的文件系统与目录结构?
  3. iOS开发——打包报错error: linker command failed with exit code 1
  4. bzoj1090 字符串折叠
  5. Git学习笔记 2,GitHub常用命令
  6. 中断函数中不能使用printf的原因
  7. Win7下JDK环境变量设置批处理(转)
  8. C++调用Lua的性能測试
  9. Unity UGUI——UI基础,Canvas
  10. Linux 下UVC&V4L2技术简单介绍(二)