DB2物化查询表(MQT)是DB2数据库中一类特殊的表,下面就为您详细介绍DB2物化查询表方面的知识,希望对您能够有所帮助。
1.DB2物化查询表与视图的区别
视图是一个查询语句。物化查询表是一个查询的结果集。
2.创建DB2物化查询表
物化查询表可以在创建临时表的时候定义,分为2种。
·系统维护的MQT
系统维护的MQT分为2种,一种是refresh immediate,另一种是refresh deferred。前者在你修改了底层表后能自动刷新,后者可以随时通过
refresh table 语句来进行刷新。对于refresh immediate类型的MQT在select时必须包含所FROM的每个表的至少一个唯一键。假如不包含唯一键,则会报错:SQLSTATE:428EC (为具体化查询表,指定的全查询无效)。
PS:增加唯一性约束的语句是:
alter table dm_gj add unique(gj_dm)
创建MQT语句:
create table topicis.mqt_test as
(select a.gj_dm 国家代码,a.gj_mc 国家名称 from topicis.dm_gj a) data initially deferred refresh immediate
data initially deferred refresh immediate 翻译成中文的意思是:数据初始化延后,立即刷新。
在creat table 之后,MQT处于暂挂状态,还需要填充数据方能用于查询:
语句:
set integrity for topicis.mqt_test immediate checked not incremental
set integrity 使完整
immediate cheched 根据定义的SELECT对数据进行检查,并刷新
not incremental 对整个表进行完整性检查
set之后,该MQT才可以用于查询
国家代码 国家名称
-------- ----------------------------------------------------------------------------------------------------
004 亚洲-阿富汗
008 欧洲-阿尔巴尼亚
012 非洲-阿尔及利亚
016 大洋洲-美属萨摩亚
020 欧洲-安道尔
024 非洲-安哥拉
028 拉丁美洲-安提瓜和巴布达
032 拉丁美洲-阿根廷
036 大洋洲-澳大利亚
040 欧洲-奥地利
044 拉丁美洲-巴哈马
048 亚洲-巴林
050 亚洲-孟加拉国
052 拉丁美洲-巴巴多斯
056 欧洲-比利时
060 北美洲-百慕大群岛
064 亚洲-不丹
068 拉丁美洲-玻利维亚
072 非洲-博茨瓦纳
074 其它-布维岛
……
需要注意的是对于系统维护的物化查询表,进行insert,update,delete都是不允许的。你可以通过对底层表的insert,update,delete来改变MQT的数据。
用户维护的MQT
用户维护的MQT与系统维护的区别在于,系统维护的MQT可以使用refresh table命令来刷新数据,用户维护的MQT不可以。用户维护的MQT可以直接insert,update,delete,系统维护的MQT不可以。
创建MQT的语句:
create table topicis.mqt_test as
(select a.gj_dm 国家代码,a.gj_mc 国家名称 from topicis.dm_gj a) data initially deferred refresh deferred maintained by user
对于用户维护的MQT来说,必然是refresh deferred 的。maintained 这个单词的意思是保持,维护.maintained by user 即为用户维护。
和系统维护的MQT一样,还需要set integrity
set integrity for topicis.mqt_test materialized query immediate unchecked
materialized:物化
immediate unchecked 表明对该表不进行完整性约束的检查。
此时,若对MQT进行查询,你会发现里面的数据为0条。因为此时该MQT里还没有数据。你需要手工插入数据,或者通过刚才的SELECT语句从底层表export,然后再import进来。
所以总体来说,用户维护的DB2物化查询表相当于基于原来的几个底层表创建一个新的实体表。
【编辑推荐】