物化视图的快速刷新(三)

转载 2012年03月24日 23:13:16

本文描述包含UNION ALL的物化视图和嵌套物化视图的快速刷新的限制,并包含了正确设置快速刷新的例子。

可以参考:

物化视图的快速刷新(一):http://yangtingkun.itpub.net/post/468/14245

物化视图的快速刷新(二):http://yangtingkun.itpub.net/post/468/16456


包含UNION ALL的物化视图:

1.UNION ALL操作必须在查询的顶层。可以有一种情况例外:UNION ALL在第二层,而第一层的查询语句为SELECT * FROM;

2.被UNION ALL操作连接在一起的每个查询块都应该满足快速刷新的限制条件;

3.SELECT列表中必须包含一列维护列,叫做UNION ALL标识符,每个UNION ALL分支的标识符列应包含不同的常量值;

4.不支持外连接、远端数据库表和包括只允许插入的聚集物化视图定义查询;

5.不支持基于分区改变跟踪(PCT)的刷新;

6.兼容性设置应设置为9.2.0。

嵌套物化视图:

嵌套物化视图的每层都必须满足快速刷新的限制条件;

对于同时包含聚集和连接的嵌套物化视图,不支持ON COMMIT的快速刷新。

下面看几个具体的例子描述上面的限制条件:

首先建立一个符合快速刷新条件的UNION ALL物化视图:

SQL> create table dim_a (id number primary key, name varchar2(30));

表已创建。

SQL> create table dim_b (id number primary key, name varchar2(30));

表已创建。

SQL> create table fact (id number, aid number, bid number, num number);

表已创建。

SQL> alter table fact add constraint fk_fact_aid foreign key (aid) references dim_a(id);

表已更改。

SQL> alter table fact add constraint fk_fact_bid foreign key (bid) references dim_b(id);

表已更改。

SQL> insert into dim_a select rownum, 'a'||rownum from user_objects;

已创建51行。

SQL> insert into dim_b select rownum, 'b'||rownum from user_objects;

已创建51行。

SQL> insert into fact select rownum, mod(rownum, 6) + 1, mod(rownum, 5 ) + 1, rownum *2 
2 from user_objects;

已创建51行。

SQL> commit;

提交完成。

SQL> create materialized view log on dim_a with rowid;

实体化视图日志已创建。

SQL> create materialized view log on dim_b with rowid;

实体化视图日志已创建。

SQL> create materialized view log on fact with rowid;

实体化视图日志已创建。

SQL> create materialized view mv_fact refresh fast on commit as 
2 select f.rowid f_rowid, a.rowid row_id, a.name name, num, 'a' marker
3 from fact f, dim_a a
4 where f.aid = a.id
5 union all
6 select f.rowid f_rowid, b.rowid row_id, b.name name, num, 'b' marker
7 from fact f, dim_b b 
8 where f.bid = b.id;

实体化视图已创建。

如果不满足UNION ALL物化视图的第一个条件,则会出现下面的情况:

SQL> drop materialized view log on dim_a;

实体化视图日志已删除。

SQL> drop materialized view log on dim_b;

实体化视图日志已删除。

SQL> drop materialized view log on fact;

实体化视图日志已删除。

SQL> create materialized view log on dim_a with rowid, sequence (id, name) 
2 including new values;

实体化视图日志已创建。

SQL> create materialized view log on dim_b with rowid, sequence (id, name) 
2 including new values;

实体化视图日志已创建。

SQL> create materialized view log on fact with rowid, sequence (aid, bid, num) 
2 including new values;

实体化视图日志已创建。

SQL> create materialized view mv_fact_err refresh fast as 
2 select name, count(*) from 
3 (
4 select f.rowid f_rowid, a.rowid row_id, a.name name, num, 'a' marker
5 from fact f, dim_a a
6 where f.aid = a.id
7 union all
8 select f.rowid f_rowid, b.rowid row_id, b.name name, num, 'b' marker
9 from fact f, dim_b b 
10 where f.bid = b.id
11 )
12 group by name;
from fact f, dim_a a
*
ERROR 位于第 5 行:
ORA-12015: 不能从复杂查询中创建一个可快速刷新的实体化视图


SQL> truncate table mv_capabilities_table;

表已截掉。

SQL> begin
2 dbms_mview.explain_mview('select name, count(*) from 
3 (
4 select f.rowid f_rowid, a.rowid row_id, a.name name, num, ''a'' marker
5 from fact f, dim_a a
6 where f.aid = a.id
7 union all
8 select f.rowid f_rowid, b.rowid row_id, b.name name, num, ''b'' marker 
9 from fact f, dim_b b 
10 where f.bid = b.id
11 )
12 group by name');
13 end;
14 /

PL/SQL 过程已成功完成。

SQL> col msgtxt format a60
SQL> select capability_name, possible, msgtxt from mv_capabilities_table 
2 where capability_name like 'REFRESH%';

CAPABILITY_NAME P MSGTXT
------------------------------ - --------------------------
REFRESH_COMPLETE Y
REFRESH_FAST N
REFRESH_FAST_AFTER_INSERT N 视图中带 UNION ALL 的 MV 太复杂
REFRESH_FAST_AFTER_INSERT N 视图合并后, 子查询或已命名的视图仍在 FROM 列表中
REFRESH_FAST_AFTER_ONETAB_DML N 查看禁用 REFRESH_FAST_AFTER_INSERT 的原因
REFRESH_FAST_AFTER_ANY_DML N 查看禁用 REFRESH_FAST_AFTER_ONETAB_DML 的原因
REFRESH_FAST_PCT N PCT 不可能在实体化视图中的任何从表上

已选择7行。

第二条限制是很正常的,不在描述,如果没有满足第三个条件:

SQL> create materialized view mv_fact_err refresh fast as 
2 select f.rowid f_rowid, a.rowid row_id, a.name name, num 
3 from fact f, dim_a a
4 where f.aid = a.id
5 union all
6 select f.rowid f_rowid, b.rowid row_id, b.name name, num 
7 from fact f, dim_b b 
8 where f.bid = b.id;
from fact f, dim_a a
*
ERROR 位于第 3 行:
ORA-12015: 不能从复杂查询中创建一个可快速刷新的实体化视图


SQL> truncate table mv_capabilities_table;

表已截掉。

SQL> begin
2 dbms_mview.explain_mview('select f.rowid f_rowid, a.rowid row_id, a.name name, num 
3 from fact f, dim_a a
4 where f.aid = a.id
5 union all
6 select f.rowid f_rowid, b.rowid row_id, b.name name, num 
7 from fact f, dim_b b 
8 where f.bid = b.id');
9 end;
10 /

PL/SQL 过程已成功完成。

SQL> select capability_name, possible, msgtxt from mv_capabilities_table 
2 where capability_name like 'REFRESH%';

CAPABILITY_NAME P MSGTXT
------------------------------ - -------------------------------
REFRESH_COMPLETE Y
REFRESH_FAST N
REFRESH_FAST_AFTER_INSERT N 实体化视图没有 UNION ALL 标记列
REFRESH_FAST_AFTER_ONETAB_DML N 查看禁用 REFRESH_FAST_AFTER_INSERT 的原因
REFRESH_FAST_AFTER_ANY_DML N 查看禁用 REFRESH_FAST_AFTER_ONETAB_DML 的原因
REFRESH_FAST_PCT N PCT 不可能在实体化视图中的任何从表上

已选择6行。

如果查询包含了外连接等,则会出现下面的情况:

SQL> create materialized view mv_fact_err refresh fast on commit as 
2 select f.rowid f_rowid, a.rowid row_id, a.name name, num, 'a' marker 
3 from fact f, dim_a a
4 where f.aid = a.id(+)
5 union all
6 select f.rowid f_rowid, b.rowid row_id, b.name name, num, 'b' marker 
7 from fact f, dim_b b 
8 where f.bid = b.id;

实体化视图已创建。

SQL> truncate table mv_capabilities_table;

表已截掉。

SQL> begin
2 dbms_mview.explain_mview('MV_FACT_ERR');
3 end;
4 /

PL/SQL 过程已成功完成。

SQL> select capability_name, possible, msgtxt from mv_capabilities_table 
2 where capability_name like 'REFRESH%';

CAPABILITY_NAME P MSGTXT
------------------------------ - ---------------------------
REFRESH_COMPLETE Y
REFRESH_FAST Y
REFRESH_FAST_AFTER_INSERT Y
REFRESH_FAST_AFTER_ONETAB_DML Y
REFRESH_FAST_AFTER_ANY_DML Y
REFRESH_FAST_PCT N PCT 不可能在实体化视图中的任何从表上

已选择6行。

物化视图可以成功建立,而且EXPLAIN_MVIEW过程也没有显示任何信息。下面我们检查一下,这个物化视图是否真正对所有操作都可以快速刷新:

SQL> select * from mv_fact_err where name = 'a1';

F_ROWID ROW_ID NAME NUM M
------------------ ------------------ -------------- ---------- -
AAACDbAAFAAAACIAAF AAACDXAAFAAAAAYAAA a1 12 a
AAACDbAAFAAAACIAAL AAACDXAAFAAAAAYAAA a1 24 a
AAACDbAAFAAAACIAAR AAACDXAAFAAAAAYAAA a1 36 a
AAACDbAAFAAAACIAAX AAACDXAAFAAAAAYAAA a1 48 a
AAACDbAAFAAAACIAAd AAACDXAAFAAAAAYAAA a1 60 a
AAACDbAAFAAAACIAAj AAACDXAAFAAAAAYAAA a1 72 a
AAACDbAAFAAAACIAAp AAACDXAAFAAAAAYAAA a1 84 a
AAACDbAAFAAAACIAAv AAACDXAAFAAAAAYAAA a1 96 a

已选择8行。

SQL> delete fact where rowid = 'AAACDbAAFAAAACIAAF';

已删除 1 行。

SQL> commit;

提交完成。

SQL> select * from mv_fact_err where name = 'a1';

F_ROWID ROW_ID NAME NUM M
------------------ ------------------ -------------- ---------- -
AAACDbAAFAAAACIAAL AAACDXAAFAAAAAYAAA a1 24 a
AAACDbAAFAAAACIAAR AAACDXAAFAAAAAYAAA a1 36 a
AAACDbAAFAAAACIAAX AAACDXAAFAAAAAYAAA a1 48 a
AAACDbAAFAAAACIAAd AAACDXAAFAAAAAYAAA a1 60 a
AAACDbAAFAAAACIAAj AAACDXAAFAAAAAYAAA a1 72 a
AAACDbAAFAAAACIAAp AAACDXAAFAAAAAYAAA a1 84 a
AAACDbAAFAAAACIAAv AAACDXAAFAAAAAYAAA a1 96 a

已选择7行。

SQL> select * from mv_fact where name = 'a1';

F_ROWID ROW_ID NAME NUM M
------------------ ------------------ -------------- ---------- -
AAACDbAAFAAAACIAAL AAACDXAAFAAAAAYAAA a1 24 a
AAACDbAAFAAAACIAAR AAACDXAAFAAAAAYAAA a1 36 a
AAACDbAAFAAAACIAAX AAACDXAAFAAAAAYAAA a1 48 a
AAACDbAAFAAAACIAAd AAACDXAAFAAAAAYAAA a1 60 a
AAACDbAAFAAAACIAAj AAACDXAAFAAAAAYAAA a1 72 a
AAACDbAAFAAAACIAAp AAACDXAAFAAAAAYAAA a1 84 a
AAACDbAAFAAAACIAAv AAACDXAAFAAAAAYAAA a1 96 a

已选择7行。

SQL> update dim_a set name = 'a11' where name = 'a1';

已更新 1 行。

SQL> commit;

提交完成。

SQL> select * from mv_fact_err where name = 'a1';

未选定行

SQL> select * from mv_fact_err where name = 'a11';

F_ROWID ROW_ID NAME NUM M
------------------ ------------------ -------------- ---------- -
AAACDbAAFAAAACIAAL AAACDXAAFAAAAAYAAA a11 24 a
AAACDbAAFAAAACIAAR AAACDXAAFAAAAAYAAA a11 36 a
AAACDbAAFAAAACIAAX AAACDXAAFAAAAAYAAA a11 48 a
AAACDbAAFAAAACIAAd AAACDXAAFAAAAAYAAA a11 60 a
AAACDbAAFAAAACIAAj AAACDXAAFAAAAAYAAA a11 72 a
AAACDbAAFAAAACIAAp AAACDXAAFAAAAAYAAA a11 84 a
AAACDbAAFAAAACIAAv AAACDXAAFAAAAAYAAA a11 96 a

已选择7行。

SQL> select * from mv_fact where name = 'a11';

F_ROWID ROW_ID NAME NUM M
------------------ ------------------ -------------- ---------- -
AAACDbAAFAAAACIAAL AAACDXAAFAAAAAYAAA a11 24 a
AAACDbAAFAAAACIAAR AAACDXAAFAAAAAYAAA a11 36 a
AAACDbAAFAAAACIAAX AAACDXAAFAAAAAYAAA a11 48 a
AAACDbAAFAAAACIAAd AAACDXAAFAAAAAYAAA a11 60 a
AAACDbAAFAAAACIAAj AAACDXAAFAAAAAYAAA a11 72 a
AAACDbAAFAAAACIAAp AAACDXAAFAAAAAYAAA a11 84 a
AAACDbAAFAAAACIAAv AAACDXAAFAAAAAYAAA a11 96 a

已选择7行。

根据测试,发现文档描述的不严谨,针对只包含连接操作构成的UNION ALL物化视图是可以支持外连接的。

SQL> create materialized view log on dim_a with rowid, sequence (id, name) 
2 including new values;

实体化视图日志已创建。

SQL> create materialized view log on dim_b with rowid, sequence (id, name) 
2 including new values;

实体化视图日志已创建。

SQL> create materialized view log on fact with rowid, sequence (aid, bid, num) 
2 including new values;

实体化视图日志已创建。

SQL> create materialized view mv_fact refresh fast on commit as 
2 select name, count(*) count, count(num) count_num, sum(num) sum_num, 'a' marker
3 from fact, dim_a where aid = dim_a.id group by name
4 union all
5 select name, count(*) count, count(num) count_num, sum(num) sum_num, 'b' marker
6 from fact, dim_b where bid = dim_b.id group by name;

实体化视图已创建。

SQL> create materialized view mv_fact_err refresh fast on commit as 
2 select name, count(*) count, count(num) count_num, sum(num) sum_num, 'a' marker
3 from fact, dim_a where aid = dim_a.id(+) group by name
4 union all
5 select name, count(*) count, count(num) count_num, sum(num) sum_num, 'b' marker
6 from fact, dim_b where bid = dim_b.id group by name;
from fact, dim_a where aid = dim_a.id(+) group by name
*
ERROR 位于第 3 行:
ORA-12054: 无法为实体化视图设置 ON COMMIT 刷新属性


SQL> create materialized view mv_fact_err refresh fast as 
2 select name, count(*) count, count(num) count_num, sum(num) sum_num, 'a' marker
3 from fact, dim_a where aid = dim_a.id(+) group by name
4 union all
5 select name, count(*) count, count(num) count_num, sum(num) sum_num, 'b' marker
6 from fact, dim_b where bid = dim_b.id group by name;
from fact, dim_a where aid = dim_a.id(+) group by name
*
ERROR 位于第 3 行:
ORA-12015: 不能从复杂查询中创建一个可快速刷新的实体化视图


SQL> truncate table mv_capabilities_table;

表已截掉。

SQL> begin
2 dbms_mview.explain_mview('select name, count(*) count, count(num) count_num, sum(num) sum_num, ''a'' marker
3 from fact, dim_a where aid = dim_a.id(+) group by name
4 union all
5 select name, count(*) count, count(num) count_num, sum(num) sum_num, ''b'' marker 
6 from fact, dim_b where bid = dim_b.id group by name');
7 end;
8 /

PL/SQL 过程已成功完成。

SQL> select capability_name, possible, msgtxt from mv_capabilities_table
2 where capability_name like 'REFRESH%';

CAPABILITY_NAME P MSGTXT
------------------------------ - --------------------------------
REFRESH_COMPLETE Y
REFRESH_FAST N
REFRESH_FAST_AFTER_INSERT N 顶层查询具有 LEFT OUTER, RIGHT OUTER 或 FULL OUTER 联接
REFRESH_FAST_AFTER_INSERT N UNION ALL MV 中的某些查询块不能快速刷新
REFRESH_FAST_AFTER_ONETAB_DML N 查看禁用 REFRESH_FAST_AFTER_INSERT 的原因
REFRESH_FAST_AFTER_ANY_DML N 查看禁用 REFRESH_FAST_AFTER_ONETAB_DML 的原因
REFRESH_FAST_PCT N PCT 不可能在实体化视图中的任何从表上

已选择7行。

可见,这里描述的不允许外连接指的是包含聚集的UNION ALL物化视图。

第五点涉及到物化视图的PCT属性,这里就不在展开讨论了,第六点是刷新UNION ALL物化视图对系统兼容性的要求,这里也不在进行测试了。

嵌套物化视图的例子:

SQL> drop materialized view mv_fact;

实体化视图已删除。

SQL> drop materialized view log on dim_a;

实体化视图日志已删除。

SQL> drop materialized view log on dim_b;

实体化视图日志已删除。

SQL> drop materialized view log on fact;

实体化视图日志已删除。

SQL> create materialized view log on dim_a with rowid;

实体化视图日志已创建。

SQL> create materialized view log on dim_b with rowid;

实体化视图日志已创建。

SQL> create materialized view log on fact with rowid;

实体化视图日志已创建。

SQL> create materialized view mv_fact refresh fast on commit as 
2 select f.rowid f_rowid, a.rowid a_rowid, b.rowid b_rowid, f.id, 
3 a.name a_name, b.name b_name, num
4 from fact f, dim_a a, dim_b b
5 where f.aid = a.id
6 and f.bid = b.id;

实体化视图已创建。

SQL> create materialized view log on mv_fact with rowid, sequence (a_name, num)
2 including new values;

实体化视图日志已创建。

SQL> create materialized view mv_mv_fact refresh fast on commit as 
2 select a_name, count(*) count, count(num) count_num, sum(num) sum_num 
3 from mv_fact
4 group by a_name;

实体化视图已创建。

SQL> select * from mv_mv_fact;

A_NAME COUNT COUNT_NUM SUM_NUM
------------------------------ ---------- ---------- ----------
a11 7 7 420
a2 9 9 450
a3 9 9 468
a4 9 9 486
a5 8 8 400
a6 8 8 416

已选择6行。

SQL> update dim_a set name = 'a1' where name = 'a11';

已更新2行。

SQL> commit;

提交完成。

SQL> select * from mv_mv_fact;

A_NAME COUNT COUNT_NUM SUM_NUM
------------------------------ ---------- ---------- ----------
a2 9 9 450
a3 9 9 468
a4 9 9 486
a5 8 8 400
a6 8 8 416
a1 7 7 420

已选择6行。

对于只包含连接或只包含聚集的嵌套物化视图是支持基于提交的快速刷新的。但是对于同时包含连接和聚集的嵌套物化视图则不支持ON COMMIT的快速刷新。

SQL> drop materialized view mv_mv_fact;

实体化视图已删除。

SQL> drop materialized view mv_fact;

实体化视图已删除。

SQL> drop materialized view log on dim_a;

实体化视图日志已删除。

SQL> create materialized view log on dim_a with rowid, sequence (id, name)
2 including new values;

实体化视图日志已创建。

SQL> create materialized view mv_fact refresh fast on commit as 
2 select f.rowid f_rowid, b.rowid b_rowid, f.id, 
3 aid, b.name b_name, num
4 from fact f, dim_b b
5 where f.bid = b.id;

实体化视图已创建。

SQL> create materialized view log on mv_fact with rowid, sequence (aid, num)
2 including new values;

实体化视图日志已创建。

SQL> create materialized view mv_mv_fact refresh fast on commit as 
2 select a.name, count(*) count, count(num) count_num, sum(num) sum_num 
3 from mv_fact, dim_a a
4 where aid = a.id
5 group by a.name;
from mv_fact, dim_a a
*
ERROR 位于第 3 行:
ORA-12053: 这不是一个有效的嵌套实体化视图


SQL> create materialized view mv_mv_fact refresh fast as 
2 select a.name, count(*) count, count(num) count_num, sum(num) sum_num 
3 from mv_fact, dim_a a
4 where aid = a.id
5 group by a.name;

实体化视图已创建。

yangtingkun 发表于:2005.01.29 03:42 ::分类: ( ORACLE ) ::阅读:(16839次) :: 评论 (20)
 关于backlog的问题 [回复]

据说有时候会很大 1 bug 2 snapshot很久没有刷新 3存在removed的snpashot但是没有在master site上自动unregister。

backlog很大影响刷新,因为snapshot log上没有索引。

你们那里会发生backlog的问题吗?有什么预防的好方法?

玉面飞龙 评论于: 2005.01.29 07:14
 [回复]

我们通过物化视图的复制在4个站点之间做单向只读的同步。

目前还没有发现什么bug和性能问题。

对于3目前还没有发现这种问题,2是肯定要避免的。
对于1,那就没有什么办法了,碰不到最好,碰到了除了升级估计没有好办法。

yangtingkun 评论于: 2005.01.29 10:20
 [回复]

SQL> select bytes,blocks ,extents from dba_segments where segment_name=upper('mlog$_customer');

BYTES BLOCKS EXTENTS
---------- ---------- ----------
417464320 25480 392

有时候我们这里的mlog$_table都好几万条记录,有时候又很少。,full table scan 肯定影响刷新的时间,不过也没有人定期重新整理

玉面飞龙 评论于: 2005.02.03 11:28
 [回复]

高水位线太高确实影响性能。

我们这里的刷新都是比较频繁的,刷新的最长间隔是1天。

不过建立物化视图后几乎很难再重建物化视图日志了,除非打算重建物化视图,重建物化视图日志导致的完全刷新在正式环境中一般是无法接受的。

yangtingkun 评论于: 2005.02.03 17:47
 [回复]

倒是可以这样做
LOCK TABLE master IN EXCLUSIVE MODE;

CREATE TABLE templog AS SELECT * FROM mlog$_t; truncate mlog$_t;INSERT INTO mlog$_tSELECT * FROM templog; drop temp

只要没有人叫,还是无为的好

玉面飞龙 评论于: 2005.02.04 10:11
 [回复]

如果你truncate的时候物化视图在刷新怎么办?
lock主表不能锁住物化视图的刷新吧?

yangtingkun 评论于: 2005.02.04 10:47
 [回复]

可以暂时broken job;
还有一个问题:据说snapshot的backlog有个可以用alter system flush share pool的bug?可是我没有在metalink上找到。
你那里遇到过类似的可以使用alter system flush share pool解决的backlog问题马?

玉面飞龙 评论于: 2005.02.15 02:49
 [回复]

没有碰到过类似的问题
alter system flush share pool和物化视图日志有什么关系呢会不会是9以前的问题啊

yangtingkun 评论于: 2005.02.15 10:18
 [回复]

确实是9i与前的问题;oracle有个cache remote table dict 缓存远程对象元信息在share pool;说在815里面修改远程对象定义的时候,oracle可能没有办法得到远程对象最新的元数据信息而使用当前缓存的对象信息,因此flush share pool。
不过我们单位是817; 不知道是否除了cache remote table dict 还有其他的原因?

玉面飞龙 评论于: 2005.02.15 23:57
 [回复]

哦,这个问题我还真没有听说过。
Oracle关于物化视图的bug确实不少。

yangtingkun 评论于: 2005.02.16 10:57
 re: 物化视图的快速刷新(三) [回复]

CREATE MATERIALIZED VIEW REFRESH FAST ON COMMIT
中select 语句的列 好像不能使用 任何 case decode语句 以及+等
需要对每一种情况 单独的 写一个select 然后union all

zhuiqiu111 评论于: 2007.08.22 16:02
 re: 物化视图的快速刷新(三) [回复]

是不是只能用union all而不能用union啊?

lisongyang 评论于: 2007.08.23 10:59
 re: 物化视图的快速刷新(三) [回复]

case和decode都会导致物化视图无法快速刷新

yangtingkun 评论于: 2007.08.27 10:06
 re: 物化视图的快速刷新(三) [回复]

只能是UNION ALL。无法对UNION的查询建立快速刷新的物化视图。

yangtingkun 评论于: 2007.08.27 10:07
 re: 物化视图的快速刷新(三) [回复]

"根据测试,发现文档描述的不严谨,针对只包含连接操作构成的UNION ALL物化视图是可以支持外连接的。"
我的数据库版本是Version 9.2.0.1.0,但是发现union all的物化视图包含外连接创建不成功.sad.gif

lisongyang 评论于: 2007.12.12 14:27
 re: 物化视图的快速刷新(三) [回复]

你的物化视图是否包含了聚集操作?

yangtingkun 评论于: 2007.12.13 00:26
 re: 物化视图的快速刷新(三) [回复]

不包含,只包含连接的.
不过,今天发现又有个奇怪的现象,左连和右连情况还不一样:
左连时
SQL> create materialized view mv_test_unionall
2 refresh fast on commit
3 with rowid
4 enable query rewrite
5 as
6 select t.rowid t_rowid,a.rowid row_id,t.id,t.name,a.val1 val,'a' marker
7 from test t,test1 a
8 where t.id(+)=a.id
9 union all
10 select t.rowid t_rowid,b.rowid row_id,t.id,t.name,b.val2 val,'b' marker
11 from test t,test2 b
12 where t.id=b.id;

Materialized view created
右连时
SQL> create materialized view mv_test_unionall
2 refresh fast on commit
3 with rowid
4 enable query rewrite
5 as
6 select t.rowid t_rowid,a.rowid row_id,t.id,t.name,a.val1 val,'a' marker
7 from test t,test1 a
8 where t.id=a.id(+)
9 union all
10 select t.rowid t_rowid,b.rowid row_id,t.id,t.name,b.val2 val,'b' marker
11 from test t,test2 b
12 where t.id=b.id;
ORA-12052: 无法快速刷新实体化视图TEST_VIEW.MV_TEST_UNIONALL
查错后发现:
MSGTXT
--------------------------------------------------------------------------------
关系不是一个已分区的表
关系不是一个已分区的表
关系不是一个已分区的表
在选择列表中缺少分区关键字或 PMARKER
关系不是一个已分区的表
在选择列表中缺少分区关键字或 PMARKER
在内部表的联接列上没有唯一性约束条件
UNION ALL MV 中的某些查询块不能快速刷新
查看禁用 REFRESH_FAST_AFTER_INSERT 的原因
查看禁用 REFRESH_FAST_AFTER_ONETAB_DML 的原因
PCT 不可能在实体化视图中的任何从表上
设置在实体化视图中遇到的运算符
设置在实体化视图中遇到的运算符
无法进行一般重写, 并且 PCT 不可能在任何从表上

相关文章推荐

物化视图的快速刷新(三)

物化视图的快速刷新(三) =========================================================== 作者: yangtingkun(http://yang...

物化视图快速刷新的限制

物化视图有三种刷新方式:COMPLETE、FAST和FORCE: (1)完全刷新(COMPLETE)会删除表中所有的记录(如果是单表刷新,可能会采用TRUNCATE的方式),然后根据物化视图中查询语...

Oracle 物化视图快速刷新限制说明

 http://blog.itpub.net/22990797/viewspace-752142/ 在老杨的Blog 看到一些列的说明,整理并转载过来,原文链接如下:   ...

物化视图的快速刷新

  • 2012年11月07日 18:54
  • 207KB
  • 下载

定位物化视图快速刷新失败的原因

 物化视图的快速刷新采用了增量的机制,在刷新时,只针对基表上发生变化的数据进行刷新。因此快速刷新是物化视图刷新方式的首选。 但是快速刷新具有较多的约束,而且对于采用ON COMMIT模式进行快...

基于分区表的物化视图快速刷新以及维护

【全文转自:http://blog.csdn.net/zjc0507/article/details/7865283】 从业DBA多年,始终致力于OLTP的实时交易类型的数据库。龙年伊始,接手了阿联...
  • BoWa21C
  • BoWa21C
  • 2013年12月27日 09:14
  • 741

Oracle 物化视图1 - 单表聚合及其快速刷新

简介 物化视图在数据仓库中常用,将结果预先计算好并存储在物化视图中,Oracle数据库通过Query Rewrite访问物化视图。可以提高SQL反应速度,改善用户体验。整个过程对用户是透明的。对于每个...

Oracle 物化视图 快速刷新 限制 说明

之前对物化视图整理的一篇介绍: http://blog.csdn.net/tianlesoftware/article/details/4713553   在老杨的Blog 看到一些...

物化视图的快速刷新

物化视图的快速刷新 物化视图的快速刷新(一) 物化视图有三种刷新方式:COMPLETE、FAST和FORCE。 完全刷新(COMPLETE)会删除表中所有的记录(如果是单表刷新,可能...

52、物化视图的快速刷新

物化视图有三种刷新方式:COMPLETE、FAST和FORCE。 完全刷新(COMPLETE)会删除表中所有的记录(如果是单表刷新,可能会采用TRUNCATE的方式),然后根据物化视图中查询语句的定...
  • shRootm
  • shRootm
  • 2012年03月02日 09:15
  • 176
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:物化视图的快速刷新(三)
举报原因:
原因补充:

(最多只允许输入30个字)