带您深入了解DB2物化查询表

数据库
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表空间静默状态的

责任编辑:段燃 来源: 互联网
相关推荐

2010-11-02 11:56:36

DB2物化视图

2010-09-30 14:57:54

DB2数据仓库

2010-08-26 16:06:38

DB2编目

2010-09-30 10:53:39

DB2表管理

2010-10-15 11:27:21

Mysql临时表

2010-11-11 13:39:57

SQL连接查询

2010-10-27 15:58:01

Oracle临时表

2010-11-04 14:12:24

DB2快照监控

2010-11-02 11:30:09

DB2索引结构

2010-11-19 15:53:28

oracle管理表空间

2010-11-02 16:39:32

DB2锁的类型

2010-07-30 17:46:46

DB2物化视图

2010-08-02 13:25:23

DB2物化视图

2010-10-19 13:26:45

SQL Server事

2010-10-15 15:32:06

Mysql外部锁定

2010-10-12 15:30:04

MySQL权限管理

2010-11-22 11:09:00

MySQL索引类型

2010-10-29 10:04:27

2010-09-28 10:46:39

sql字段类型

2010-08-20 13:33:50

DB2物化视图
点赞
收藏

51CTO技术栈公众号