MQT表2
DB2 物化查詢表 MQT(MATERIALIZED QUERY TABLES)
儲存了一個查詢的結果,當我們查詢相關表時,DB2 會自動決定是使用原表還是使用物化查詢表。當資料庫中有海量資料時, 使用物化查詢表可以極大的提高查詢速度。 但是, 有一利就有一弊,維護物化查詢表也是相當耗時的。 所以, 物化查詢表廣泛應用在資料倉儲和海量數量的報表查詢中,這類查詢的特點是:資料量大、經常需要分組統計、資料不會頻繁變更。正因為這些特點,在這些場合中物化查詢表可以充分發揮它的優勢。
語法
create table
示例:
CREATE TABLE emp_summary AS
(
SELECT workdept, COUNT(*) AS crows, SUM(empno) AS sumno
FROM employee
GROUP BY workdept
)DATA INITIALLY DEFERRED
REFRESH IMMEDIATE;
在定義物化查詢表時,我們可以指定在原始表資料改變時,是立即重新整理物化查詢表(REFRESH IMMEDIATE)呢,還是延遲重新整理(REFRESH DEFERRED);我們還可以指定,在適當的時候,允許優化器使用物化查詢表(ENABLE QUREY OPTIMIZATION)呢,還是禁止使用(DISABLE QUREY OPTIMIZATION]);我們還可以指定,物化查詢表是由系統維護(MAINTAINED BY SYSTEM)呢,還是由使用者維護(MAINTAINED BYUSER)。
如果我們將物化查詢表定義為延遲重新整理(REFRESH DEFERRED),那麼在使用物化查詢表之前, 我們必須使用REFRESH TABLE 語句重新整理它。 如果定義為由使用者負責維護物化查詢表時,使用者可以對物化查詢表進行insert update delete等操作,此時,物化查詢表將不能 REFRESH 了。
維護物化查詢表是相當耗時的,為了提高維護效率,我們可以給延遲重新整理(REFRESHDEFERRED) 的物化查詢表定義一個staging表。 staging表用來對物化查詢表執行增量重新整理,當重新整理完成時,staging表就會被刪除。對於上面定義的物化查詢表,我們可以定義如下 staging表:
CREATE TABLE emp_summary_st
(
workdept,
crows,
sumno,
GLOBALTRANSID,
GLOBALTRANSTIME
)FOR emp_summary PROPAGATE IMMEDIATE;
PROPAGATE IMMEDIATE 子句表示, 原始表做出的任何更改, 都將被累積在staging表中。
GLOBALTRANSID 表示每個被傳播的行對應的全域性事務ID。
GLOBALTRANSTIME 表示事務的時間戳。
taging表建立後, 處於檢查暫掛狀態, 我們可以使用SET INTEGRITY語句將表設定為正常狀態, 這時候, 我們就可以使用staging表來重新整理物化查詢表了。
SET INTEGRITY FOR emp_summary_st STAGING IMMEDIATE UNCHECKED;
REFRESH TABLE emp_summary;
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/23577591/viewspace-704317/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- DB2資料庫物化檢視:MQT物化查詢表的使用DB2資料庫MQQT
- MQT介紹MQQT
- db2表空間DB2
- db2表掛起DB2
- db2大表統計DB2
- canvas圖表(2) - 折線圖Canvas
- mysql分割槽表小結2MySql
- DB2 批量刪除表DB2
- DB2表空間增加DB2
- 必看,經典sql面試題2(學生表_課程表_成績表_教師表)SQL面試題
- excel表1和表2資料匹配 vlookup跨表兩個表格匹配Excel
- DB2的REORG_學習(2)_表重組DB2
- DB2頁大小、表大小和表空間大小限制DB2
- ActiveReports 報表應用教程 (2)---清單類報表
- DB2匯出表結構、表資料小結DB2
- (2) 電商資料庫表設計資料庫
- MySQL系列:資料表基本操作(2)MySql
- DB2匯出給定表DB2
- db2 表被誤刪(drop)DB2
- 檢視DB2表結構DB2
- 快速清空DB2表記錄DB2
- DB2_使用大表空間DB2
- DB2_收縮表空間DB2
- L2-042 老闆的作息表
- [NOIP 2024 模擬2]表
- db2 sql批量插入一張表插入另一張表DB2SQL
- 細說 Angular 2+ 的表單(二):響應式表單Angular
- --查詢班級表、課程表、學生選課表、學生表、成績表、15(3+2)計算
- db2 建立bufferpool,表空間DB2
- Symfony2的表單事件 FormEventSubscriber事件ORM
- DB2_收集表統計資料DB2
- flink讀取iceberg v2表
- GORM many2many、many2one、one2many關聯表的操作GoORM
- 細說 Angular 2+ 的表單(一):模板驅動型表單Angular
- PostgreSQL 原始碼解讀(94)- 分割槽表#2(資料插入路由#2)SQL原始碼路由
- DB2&ORACLE中更換的表所在的表空間的方法DB2Oracle
- 達夢SQL優化-回表BLKUP2SQL優化
- Bootstrap select2 ,table, 清空表單formbootORM