ITPub博客

首页 > Linux操作系统 > Linux操作系统 > 【DB2】物化查询表(MQT)详解

【DB2】物化查询表(MQT)详解

原创 Linux操作系统 作者:fengjin821 时间:2009-09-16 22:42:54 0 删除 编辑

物化查询表(MQT)

1.物化查询表与视图的区别
视图是一个查询语句。物化查询表是一个查询的结果集。

2.创建物化查询表
物化查询表可以在创建临时表的时候定义,分为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进来。
所以总体来说,用户维护的MQT相当于基于原来的几个底层表创建一个新的实体表。

 

 

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/13165828/viewspace-614844/,如需转载,请注明出处,否则将追究法律责任。

下一篇: DB2 MQT介绍
请登录后发表评论 登录
全部评论

注册时间:2009-04-29

  • 博文量
    191
  • 访问量
    512231