带您深入了解DB2物化查询表
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物化查询表相当于基于原来的几个底层表创建一个新的实体表。
  
【编辑推荐】
DB2分区数据库的前滚操作
三类DB2数据库备份方案
DB2批量执行SQL脚本的实现
在线改变DB2页大小的实现
DB2表空间静默状态的
网站名称:带您深入了解DB2物化查询表
标题路径:http://jxruijie.cn/article/cdessod.html

 
                