使用 MQT物化查询表(Materialized Query Tables MQT)
MQT 的定义基于查询的结果 MQT 可以显著提高查询的性能 本教程将介绍 MQT 总结表(summary table)和 staging 表 并通过一些实用的例子展示如何创建和使用物化查询表
MQT 是基于查询的结果定义的一个表 MQT 中包含的数据来自 MQT 定义所基于的一个或多个表 总结表(也称自动总结表[AST])对于 IBM DB for Linux UNIX and Windows 的用户来说应该感到比较熟悉 它们可以看作是特殊的 MQT fullselect 是总结表定义的一部分 它包含一个 GROUP BY 子句 该子句总结 fullselect 中所引用表中的数据
您可以将 MQT 看作一种物化的视图 视图和 MQT 都是基于一个查询来定义的 每当视图被引用时 视图所基于的查询便会运行 但是 MQT 实际上会将查询结果存储为数据 您可以使用 MQT 中的这些数据 而不是使用底层表中的数据 MQT 可以显著提高查询的性能 尤其是提高复杂查询的性能 如果优化器确定查询或查询的一部分可以用一个 MQT 来解决 那么查询就可以被重写以便利用 MQT MQT 可以在创建表时定义 可以定义为由系统维护 也可以定义为由用户维护
这种 MQT 中的数据是由系统维护的 当创建这种类型的 MQT 时 可以指定表数据是 REFRESH IMMEDIATE 还是 REFRESH DEFERRED 通过 REFRESH 关键字可以指定如何维护数据 DEFERRED 的意思是 表中的数据可以在任何时候通过 REFRESH TABLE 语句来刷新 系统维护的 MQT 不管是 REFRESH DEFERRED 类型的还是 REFRESH IMMEDIATE 类型的 对它们的插入 更新或删除 *** 作都是不允许的 但是 对于 REFRESH IMMEDIATE 类型的系统维护的 MQT 可以通过 对底层表的更改(即插入 更新或删除 *** 作)来更新
lishixinzhi/Article/program/DB2/201311/21922
案例描述:
在dbname数据库中创建dbname1数据库视图。
步骤(红字标识的是可替换的内容):
1.连接数据库
connect to dbname user username using password
2. 创建WRAPPER 的 DDL 语句
CREATE WRAPPER "DRDA"
LIBRARY 'db2drda.dll'
OPTIONS (DB2_FENCED 'N')
3. 创建SERVER 的 DDL 语句
CREATE SERVER tempserver
TYPE DB2/UDB
VERSION 8.1
WRAPPER DRDA
AUTHORIZATION "username1"
PASSWORD "password1"
OPTIONS
(DBNAME 'dbname1')
上面指定的dbname1是远程数据库的名称,username1和password1是它的用户名及密码。
4. 创建USER MAPPING 的 DDL 语句
CREATE USER MAPPING FOR db2admin
SERVER tempserver --此处tempserver名称就是步骤3创建的server
OPTIONS
(REMOTE_AUTHID 'dbname1',
REMOTE_PASSWORD 'password'
)
5. 创建跨库视图
CREATE NICKNAME PERSON FOR tempserver.PERSON
create view SYS_PERSON as
select *
from PERSON
需要注意,上面语句中NICKNAME和VIEW的名称不能相同。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)