----start
db2 物化查詢表mqt(materialized query tables)儲存了乙個查詢的結果,當我們查詢相關表時,db2會自動決定是使用原表還是使用物化查詢表。當資料庫中有海量資料時,使用物化查詢表可以極大的提高查詢速度。但是,有一利就有一弊,維護物化查詢表也是相當耗時的。所以,物化查詢表廣泛應用在資料倉儲和海量數量的報表查詢中,這類查詢的特點是:資料量大、經常需要分組統計、資料不會頻繁變更。正因為這些特點,在這些場合中物化查詢表可以充分發揮它的優勢。
定義了物化查詢表後,如果我們執行以下sql,db2優化器將使用mqt
db2 優化器將上面的sql轉化成下面這樣
在定義物化查詢表時,我們可以指定在原始表資料改變時,是立即重新整理物化查詢表(refresh immediate)呢,還是延遲重新整理(refresh deferred );我們還可以指定,在適當的時候,允許優化器使用物化查詢表(enable qurey optimization)呢,還是禁止使用(disable qurey optimization]);我們還可以指定,物化查詢表是由系統維護(maintained by system)呢,還是由使用者維護(maintained by user)。
如果我們將物化查詢表定義為延遲重新整理(refresh deferred ),那麼在使用物化查詢表之前,我們必須使用refresh table 語句重新整理它。如果定義為由使用者負責維護物化查詢表時,使用者可以對物化查詢表進行insert update delete 等操作,此時,物化查詢表將不能refresh了。
維護物化查詢表是相當耗時的,為了提高維護效率,我們可以給延遲重新整理(refresh deferred)的物化查詢表定義乙個staging 表。staging 表用來對物化查詢表執行增量重新整理,當重新整理完成時,staging 表就會被刪除。對於上面定義的物化查詢表,我們可以定義如下staging 表
propagate immediate 子句表示,原始表做出的任何更改,都將被累積在 staging 表中。globaltransid表示每個被傳播的行對應的全域性事務 id)。 globaltranstime表示事務的時間戳。taging 表建立後,處於檢查暫掛狀態,我們可以使用 set integrity 語句將表設定為正常狀態,這時候,我們就可以使用staging 表來重新整理物化查詢表了。
----更多參見:db2 sql 精萃
----last updated on 2010.1.21
----written by shangbo on 2010.1.21
----end
db2 表關聯查詢
今天在mapreduce的練習中看到了乙個題目 file child parent tom lucy tom jack jone lucy jone jack lucy mary lucy ben jack alice jack jesse terry alice terry jesse phili...
DB2遞迴查詢
遞迴 sql 在 db2 中通過公共表表示式 cte,common table expression 來實現。遞迴 sql 由遞迴 cte 以及對遞迴 cte 結果的查詢組成。那什麼是遞迴 cte 呢?簡言之,如果 cte 中的 fullselect 在 from 子句中引用到 cte 本身,就是遞...
DB2跨庫查詢表資料
1 登入db2資料庫後,查詢當前使用者的使用者模式 select current schema from sysibm.dual 3 建立伺服器 server create server tempserver type db2 udb version 9.7 authorization remote...