Oracle11gr2物化檢視日誌新增COMMIT SCN語句

yangtingkun發表於2010-03-07

11.2中,物化檢視日誌也新增了一些功能,對於本地物化檢視而言,現在可以利用COMMIT SCN來替代以前版本中的TIMESTAMP方式來進行重新整理。

 

 

看一個簡單的例子:

SQL> SELECT * FROM V$VERSION;

BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production
PL/SQL Release 11.2.0.1.0 - Production
CORE    11.2.0.1.0      Production
TNS for Linux: Version 11.2.0.1.0 - Production
NLSRTL Version 11.2.0.1.0 - Production

SQL> CREATE TABLE T
  2  (ID NUMBER PRIMARY KEY,
  3  NAME VARCHAR2(30),
  4  AGE NUMBER);

表已建立。

SQL> CREATE MATERIALIZED VIEW LOG ON T WITH COMMIT SCN;

實體化檢視日誌已建立。

SQL> INSERT INTO T
  2  VALUES (1, 'TEST', 18);

已建立 1 行。

SQL> SELECT * FROM MLOG$_T;

        ID D O CHANGE_VECTOR$$                     XID$$
---------- - - ------------------------------ ----------
         1 I N FE                             2.8148E+15

和普通的TIMESTAMP的物化檢視不同,物化檢視日誌中不再記錄TIMESTAMP列,而是記錄了修改的XID資訊,透過XIDSCN來判斷一個物化檢視是否需要重新整理對應的記錄。

透過這種方式,可以提高物化檢視重新整理的效能。

不過由於SCN只能用在本地使用,因此這種物化檢視日誌只支援本地的物化檢視,而遠端物化檢視則不支援。

SQL> CREATE DATABASE LINK TEST112@TEST112 USING '172.25.198.230/TEST112';

資料庫連結已建立。

SQL> SELECT GLOBAL_NAME FROM GLOBAL_NAME@TEST112@TEST112;

GLOBAL_NAME
-----------------------------------------------------------------
TEST112

SQL> CREATE MATERIALIZED VIEW MV_T1
  2  REFRESH FAST
  3  AS SELECT * FROM T@TEST112@TEST112;
CREATE MATERIALIZED VIEW MV_T1
*
1 行出現錯誤:
ORA-32415:
具有基於提交 SCN 的實體化檢視日誌的從表不支援可快速重新整理的遠端實體化檢視


SQL> CREATE MATERIALIZED VIEW MV_T
  2  REFRESH FAST
  3  AS SELECT * FROM T;

實體化檢視已建立。

由於當前只有一個11.2版本的資料庫,為了演示遠端訪問,建立了一個指向當前資料庫的資料庫鏈,可以看到建立本地的物化檢視沒有問題,但是遠端物化檢視不能基於SCN的物化檢視日誌。

除了可以建立基於主鍵或ROWID的單表物化檢視外,本地基於連線、聚集或UNION ALL的物化檢視都可以利用COMMIT SCN的物化檢視日誌。

但是,如果表中包含了LOB列,則建立COMMIT SCN的物化檢視日誌報錯:

SQL> CREATE TABLE T_LOB
  2  (ID NUMBER PRIMARY KEY,
  3  CONTENT CLOB);

表已建立。

SQL> CREATE MATERIALIZED VIEW LOG ON T_LOB WITH COMMIT SCN;
CREATE MATERIALIZED VIEW LOG ON T_LOB WITH COMMIT SCN
*
1 行出現錯誤:
ORA-32421:
具有 LOB 列的表不支援基於提交 SCN 的實體化檢視日誌

另外,如果物化檢視依賴多個物化檢視日誌,那麼這些物化檢視必須都是基於TIMESTAMP或者都是基於COMMIT SCN的,而不能是二者混和的,否則會報錯:

SQL> CREATE TABLE T1           
  2  (ID NUMBER PRIMARY KEY,
  3  NAME VARCHAR2(30));

表已建立。

SQL> CREATE TABLE T2
  2  (ID NUMBER PRIMARY KEY,
  3  FID NUMBER, 
  4  ADDRESS VARCHAR2(30));

表已建立。

SQL> CREATE MATERIALIZED VIEW LOG ON T1 WITH ROWID (ID);

實體化檢視日誌已建立。

SQL> CREATE MATERIALIZED VIEW LOG ON T2 WITH ROWID, COMMIT SCN (ID, FID);

實體化檢視日誌已建立。

SQL> CREATE MATERIALIZED VIEW MV_T12
  2  REFRESH FAST
  3  AS SELECT T1.ROWID ROWID1, T2.ROWID ROWID2, T1.ID ID1, T2.ID ID2
  4  FROM T1, T2
  5  WHERE T1.ID = T2.FID;
FROM T1, T2
     *
4 行出現錯誤:
ORA-32414:
實體化檢視日誌互不相容, 無法進行快速重新整理

這是由於包含COMMIT SCN的物化檢視日誌的快速重新整理方式已經發生了改變。

 

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/4227/viewspace-628847/,如需轉載,請註明出處,否則將追究法律責任。

相關文章