自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

DB2數(shù)據(jù)庫物化視圖之MQT物化查詢表的正確應(yīng)用

數(shù)據(jù)庫
本文主要向你介紹的是DB2數(shù)據(jù)庫物化視圖之MQT物化查詢表的正確使用方案,以下就是文章的主要內(nèi)容的詳細描述,望大家會對其有更好的了解。

以下的文章主要介紹的是DB2數(shù)據(jù)庫物化視圖之MQT物化查詢表的正確使用方案,如果你是DB2數(shù)據(jù)庫物化視圖之MQT物化查詢表的正確使用方案實際應(yīng)用方面的新手,你就可以通過以下的文章對其有個更好的了解。

 

使用 MQT物化查詢表(Materialized Query Tables, MQT)

MQT 的定義基于查詢的結(jié)果。MQT 可以顯著提高查詢的性能。本教程將介紹 MQT、總結(jié)表(summary table)和 staging 表,并通過一些實用的例子展示如何創(chuàng)建和使用物化查詢表。

 

MQT 是基于查詢的結(jié)果定義的一個表。MQT 中包含的數(shù)據(jù)來自 MQT 定義所基于的一個或多個表??偨Y(jié)表(也稱自動總結(jié)表[AST])對于 IBM DB2 for Linux, UNIX, and Windows 的用戶來說應(yīng)該感到比較熟悉,它們可以看作是特殊的 MQT。fullselect 是總結(jié)表定義的一部分,它包含一個 GROUP BY 子句,該子句總結(jié) fullselect 中所引用表中的數(shù)據(jù)。

 

您可以將 MQT 看作一種物化的視圖。視圖和 MQT 都是基于一個查詢來定義的。每當視圖被引用時,視圖所基于的查詢便會運行。但是,MQT 實際上會將查詢結(jié)果存儲為數(shù)據(jù),您可以使用 MQT 中的這些數(shù)據(jù),而不是使用底層表中的數(shù)據(jù)。

MQT 可以顯著提高查詢的性能,尤其是提高復(fù)雜查詢的性能。如果優(yōu)化器確定查詢或查詢的一部分可以用一個 MQT 來解決,那么查詢就可以被重寫以便利用 MQT。MQT 可以在創(chuàng)建表時定義,可以定義為由系統(tǒng)維護,也可以定義為由用戶維護。

 

這種 MQT 中的數(shù)據(jù)是由系統(tǒng)維護的。當創(chuàng)建這種類型的 MQT 時,可以指定表數(shù)據(jù)是 REFRESH IMMEDIATE 還是 REFRESH DEFERRED。通過 REFRESH 關(guān)鍵字可以指定如何維護數(shù)據(jù)。DEFERRED 的意思是,表中的數(shù)據(jù)可以在任何時候通過 REFRESH TABLE 語句來刷新。

系統(tǒng)維護的 MQT,不管是 REFRESH DEFERRED 類型的還是 REFRESH IMMEDIATE 類型的,對它們的插入、更新或刪除操作都是不允許的。但是,對于 REFRESH IMMEDIATE 類型的系統(tǒng)維護的 MQT,可以通過 對底層表的更改(即插入、更新或刪除操作)來更新。

 

下面的小節(jié)將展示一個創(chuàng)建 REFRESH IMMEDIATE 類型的系統(tǒng)維護的 MQT 的例子。這個表名為 EMP,它基于 SAMPLE 數(shù)據(jù)庫中的底層表 EMPLOYEE 和 DEPARTMENT。由于 REFRESH IMMEDIATE MQT 要求來自查詢內(nèi)引用的每個表至少有一個惟一鍵要出現(xiàn)在 select 列表中,所以我們首先在 EMPLOYEE 表的 EMPNO 列上定義一個惟一性約束,另外還要在 DEPARTMENT 表的 DEPTNO 列上定義一個惟一性約束。

DATA INITIALLY DEFERRED 子句的意思是,在執(zhí)行 CREATE TABLE 語句的時候,并不將數(shù)據(jù)插入到表中。MQT 被創(chuàng)建好之后,DB2數(shù)據(jù)庫就會處于檢查暫掛(check pending)狀態(tài),在對它執(zhí)行 SET INTEGRITY 語句之前,不能查詢它。IMMEDIATE CHECKED 子句指定,必須根據(jù)用于定義該 MQT 的查詢對數(shù)據(jù)進行檢查,并刷新數(shù)據(jù)。NOT INCREMENTAL 子句指定對整個表進行完整性檢查。

 

 

  1. CONNECT TO SAMPLE  
  2. ...  
  3. ALTER TABLE EMPLOYEE ADD UNIQUE (EMPNO)  
  4. ALTER TABLE DEPARTMENT ADD UNIQUE (DEPTNO)  
  5. CREATE TABLE EMP AS (SELECT E.EMPNO, E.FIRSTNME, E.LASTNAME, E.PHONENO, D.DEPTNO,  
  6. SUBSTR(D.DEPTNAME, 1, 12) AS DEPARTMENT, D.MGRNO FROM EMPLOYEE E, DEPARTMENT D  
  7. WHERE E.WORKDEPT = D.DEPTNO)  
  8. DATA INITIALLY DEFERRED REFRESH IMMEDIATE  
  9. SET INTEGRITY FOR EMP IMMEDIATE CHECKED NOT INCREMENTAL   

以上的相關(guān)內(nèi)容就是對DB2數(shù)據(jù)庫物化視圖:MQT物化查詢表的使用的介紹,望你能有所收獲。 

【編輯推薦】

  1. IBM DB2 UDB 在線備份與恢復(fù)完美演習!
  2. 對DB2 Online備份方案的具體描述
  3. DB2數(shù)據(jù)庫備份與恢復(fù)命令的總結(jié)描述
  4. Oracle移植到DB2數(shù)據(jù)庫中常出現(xiàn)的錯誤有哪些?
  5. 3種DB2數(shù)據(jù)遷移的操作方案與其的缺點與注意事項

 

責任編輯:佚名 來源: 網(wǎng)易科技報道
相關(guān)推薦

2010-08-20 13:33:50

DB2物化視圖

2010-07-30 17:46:46

DB2物化視圖

2010-08-02 13:25:23

DB2物化視圖

2010-07-27 14:26:08

DB2數(shù)據(jù)庫物化視圖

2010-08-19 17:17:08

DB2數(shù)據(jù)庫

2010-08-10 09:44:02

DB2MQT物化查詢表

2010-11-02 11:56:36

DB2物化視圖

2010-11-02 11:02:48

DB2物化查詢表

2010-08-04 16:08:23

DB2 物化查詢表

2010-08-13 11:02:09

DB2數(shù)據(jù)庫Table

2010-08-18 16:45:40

IBM DB2 Cat

2010-08-11 15:48:04

DB2編程

2010-08-11 15:48:04

DB2編程

2010-08-11 17:28:56

DB2 數(shù)據(jù)倉庫技術(shù)

2010-08-16 10:10:27

DB2常用函數(shù)

2010-08-04 15:23:04

DB2用戶密碼

2010-08-31 17:34:46

DB2

2010-07-30 09:57:31

2010-08-26 16:00:31

DB2數(shù)據(jù)庫安裝

2010-09-07 09:31:03

DB2數(shù)據(jù)庫鎖表
點贊
收藏

51CTO技術(shù)棧公眾號