【ORACLE】物化檢視快速重新整理限制條件
快速重新整理的物化檢視建立比較麻煩,限制條件比較多,本文參考Oracle 11g 11.2版本官方文件,總結一般情況、含有聯接、含有聚合計算、UNION ALL等情況下的限制條件。
所有快速重新整理的物化檢視都必須滿足的條件
定義物化檢視的查詢語句限制如下:
- 1.物化檢視中不能含有非重複表示式的引用,例如
SYSDATE
和ROWNUM
. - 2.物化檢視中不能出現
RAW
或LONG RAW
資料型別的引用。 - 3.查詢語句的
SELECT
部分語不能出現子查詢。 - 4.
SELECT
子句部分不能包含分析性質的函式,例如RANK
。 - 5.不能含有
MODEL
子句。 - 6.子查詢中不能含有
HAVING
子句。 - 7.不能出現含有
ANY
,ALL
或NOT EXISTS
的巢狀子查詢。 - 8.不能含有
[START WITH …] CONNECT BY
子句。 - 9.不能包含不同站點的多個明細表。
- 10.
ON COMMIT
重新整理方式的物化檢視不能有遠端明細表的引用。 - 11.巢狀物化檢視必須含有表聯接或者聚合計算。
- 12.物化檢視包含聯接和
GROUP BY
子句的聚合計算時,不能select from 一個有索引的表。
只包含聯接的物化檢視快速重新整理限制條件
定義物化檢視的查詢語句只含有聯接且沒有聚合計算,實現快速重新整理除滿足通用條件外,還要滿足條件如下:
- 1.不能含有
GROUP BY
子句或聚合計算。 - 2.
FROM
中出現的每個基表的ROWID
必須出現在SELECT
子句中。 - 3.
FROM
中出現的每個基表都必須建立基於ROWID
的物化檢視日誌(MATERIALIZED VIEW LOG)。 - 4.
SELECT
子句中不能含有object型別的列。
另外,以下情況將會影響快速重新整理的效率:
- 1.定義的查詢語句含有外聯接,如果這樣的話,請考慮重寫查詢語句改為內連線。
- 2.
SELECT
子句中含有多個表的列運算。
包含聚合的物化檢視快速重新整理限制
定義物化檢視的查詢語句含有聚合計算,實現快速重新整理除滿足通用條件外,還要滿足條件如下:
- 1.所有基表必須建立物化檢視日誌,建立日誌必須滿足:
- 1.1 包含在物化檢視中引用的所有列,確保這些列沒有被加密。
- 1.2 需要指定
ROWID
和INCLUDING NEW VAUES
。 - 1.3 如果基表會有插入/直接匯入,刪除,更新資料的混合操作,需要指定
SEQUENCE
子句。
- 2.只有
SUM
,COUNT
,AVG
,STDDEV
,VARIANCE
,MIN
和MAX
才支援快速重新整理。 - 3.必須有寫
COUNT(*)
。 - 4.聚合函式必須出現在表示式的最外層,也就是說像
AVG(AVG(X))
或AVG(x)+AVG(x)
都是不允許的。 - 5.對每一個聚集計算如
AVG(expr)
,相應的COUNT(expr)
也必須要有,Oracle建議SUM(expr)
也寫上。 - 6.如果含有
VARIANCE(expr)
或STDDEV(expr)
,COUNT(expr)
和SUM(expr)
都必須寫,Oracle建議SUM(expr*expr)
也寫上。 - 7.查詢中定義的
SELECT
列不能是來自多個表的列複雜運算,可以考慮使用巢狀物化檢視作為變通方案。 - 8.
GROUP BY
中的列都要在SELECT
裡出現。 - 9.如果物化檢視日誌中過濾列欄位型別為
CHAR
,那麼基表所在的資料庫和物化檢視所在的資料庫的字符集必須要一樣。 - 10.如果物化檢視有以下情況,增量重新整理只支援DML操作中的
INSERT
和直接裝載(direct loads)操作,這種物化檢視叫只能插入(insert-only)的物化檢視:
- 10.1 物化檢視有
MIN
或者MAX
聚合計算。 - 10.2 物化檢視有
SUM(expr)
但是沒有COUNT(expr)
。 - 10.3 物化檢視沒有指定
COUNT(*)
。
- 10.1 物化檢視有
- 11.含有
MAX
或MIN
聚合計算的物化檢視如果沒有WHERE
子句,是支援基表增刪改的增量重新整理的。 - 12.物化檢視的
FROM
子句中有普通檢視或者子查詢,如果普通檢視可以被完全合併是可以支援增量重新整理的。(PS.這一條不懂啥意思) - 13.如果沒有外聯接,
WHERE
子句沒有限制。 - 14.有外聯接和聚合計算的物化檢視是支援增量重新整理的,只有外接表資料變更的時候。另外,唯一約束必須存在於表的內連線列上。如果有外聯接,所有連線必須用
AND
和=
操作符。 - 15.對於含有
CUBE
,ROLLUP
,GOUPING SETS
的物化檢視,會有以下限制:
- 15.1
SELECT
列表要包含GROUP BY
所有欄位的GROUPING_ID
或GROUPING
。舉個例子,GROUP BY
子句是GROUP BY CUBE(a, b)
,那麼SELECT
列表中應該包含GROUPING_ID(a, b)
或GROUPING(a) , GROUPING(b)
,這樣才會使物化檢視增量重新整理。 - 15.2
GROUP BY
不能導致多個groupings的情況,比如,GROUP BY a, ROLLUP(a, b)
就不會增量重新整理因為這會導致多個groupings,(a), (a, b), (a)
。
- 15.1
包含UNION ALL的物化檢視快速重新整理限制
含有UNION ALL
的物化檢視REFRESH FAST
需要滿足以下條件:
1.
UNION ALL
操作必須在查詢語句的頂層。UNION ALL
不能被巢狀在一個子查詢裡面,這裡有一個例外:SELECT * FROM
後面直接跟含有UNION ALL
的子查詢。例如:
CREATE VIEW view_with_unionall AS
(SELECT c.rowid crid, c.cust_id, 2 umarker
FROM customers c WHERE c.cust_last_name = ‘Smith’
UNION ALL
SELECT c.rowid crid, c.cust_id, 3 umarker
FROM customers c WHERE c.cust_last_name = ‘Jones’);CREATE MATERIALIZED VIEW unionall_inside_view_mv
REFRESH FAST ON DEMAND AS
SELECT * FROM view_with_unionall;2.
UNION ALL
的每一部分查詢必須滿足聚合物化檢視貨連線物化檢視的增量重新整理條件。相應的物化檢視日誌也要建上。- 3.
UNION ALL
的每一部分查詢必須包含一列標記列,這個標識列必須是數值或者字元型的固定數值,而且這一列在每一部分的查詢中SELECT
列順序相同。 - 4.一些特性如外聯接,只能插入(insert-only)的物化檢視查詢和遠端表都是不支援
UNION ALL
物化檢視的。然而,那些被用於複製的不包含聯接和聚集計算的物化檢視,是可以增量重新整理的。 - 5.建立包含
UNION ALL
的增量重新整理物化檢視,版本需滿足9.2.0或更高才能滿足相容。
參考:
https://docs.oracle.com/cd/E11882_01/server.112/e25554/basicmv.htm#i1007013
相關文章
- Oracle 物化檢視 快速重新整理 限制 說明Oracle
- Oracle如何根據物化檢視日誌快速重新整理物化檢視Oracle
- 【物化檢視】根據物化檢視日誌快速重新整理物化檢視的過程
- 物化檢視的快速重新整理測試與物化檢視日誌
- oracle 物化檢視重新整理方法Oracle
- Oracle 物化檢視快速重新整理對效能的影響Oracle
- Oracle 物化檢視1 - 單表聚合及其快速重新整理Oracle
- 10G物化檢視PCT快速重新整理不再需要物化檢視日誌(三)
- 10G物化檢視PCT快速重新整理不再需要物化檢視日誌(二)
- 10G物化檢視PCT快速重新整理不再需要物化檢視日誌(一)
- oracle 物化檢視的自動重新整理方法Oracle
- 12c 物化檢視 - 對快速重新整理的理解
- 淺析為何Oracle物化檢視對distinct, group by不支援快速重新整理Oracle
- oracle物化檢視Oracle
- 包含複雜查詢的快速重新整理的物化檢視
- 12c 物化檢視 - 理解完全重新整理的物化檢視工作原理
- oracle 建立物化檢視Oracle
- Oracle 物化檢視建立Oracle
- 給物化檢視設定自動快速重新整理功能失敗
- 建立快速重新整理物化檢視使用with rowid還是with primary key?
- ZT 定位導致物化檢視無法快速重新整理的原因
- 物化檢視重新整理並非完全根據物化檢視日誌記錄
- 總結在SQL Server檢視管理中限制條件SQLServer
- SQL Server檢視管理中的四個限制條件SQLServer
- 基於複製的多層巢狀快速重新整理物化檢視巢狀
- 物化檢視日誌與增量重新整理
- StarRocks 物化檢視重新整理流程及原理
- Oracle物化檢視詳解Oracle
- ORACLE物化檢視測試Oracle
- Oracle 物化檢視案例分享Oracle
- Oracle物化檢視語法Oracle
- ORACLE物化檢視入門Oracle
- oracle物化檢視系列(二)Oracle
- oracle物化檢視系列(一)Oracle
- ogg 同步 物化檢視建立限制 Materialized ViewZedView
- Oracle 檢視可以DML操作的條件Oracle
- ORA-12052,不能建立快速重新整理物化檢視的解決
- 物化檢視重新整理的問題及分析