带您深入了解DB2物化查询表
创始人
2024-07-17 01:41:25
0

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

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...