17

2 つのテーブルの LEFT JOIN から MATERIALIZED VIEW を作成したいと考えています。ただし、次のエラーが発生します。

    SELECT field1 
     FROM table_1 a 
     LEFT JOIN table_2 b 
     ON a.field1=b.field2

ORA-12054: マテリアライズド・ビューのON COMMITリフレッシュ属性を設定できません

ただし、次のように動作します。

SELECT field1 
 FROM table_1 a, table_2 b 
 WHERE a.field1=b.field2

なぜこれが起こっているのか、誰にも考えがありますか。

助けてくれてありがとう

4

3 に答える 3

44

There are two conditions that are not satisfied to make that materialized view refresh fast. First one is that you did not specify the rowid columns of every table involved. And the second one is an undocumented restriction: ANSI-joins are not supported.

Here is an example with DEPT being table_1, alias a and EMP being table_2, alias b:

SQL> create materialized view log on emp with rowid
  2  /

Materialized view log created.

SQL> create materialized view log on dept with rowid
  2  /

Materialized view log created.

SQL> create materialized view empdept_mv
  2    refresh fast on commit
  3  as
  4  select a.deptno
  5    from dept a
  6         left join emp b on (a.deptno = b.deptno)
  7  /
  from dept a
       *
ERROR at line 5:
ORA-12054: cannot set the ON COMMIT refresh attribute for the materialized view

That mimics your situation. First add the rowid's:

SQL> create materialized view empdept_mv
  2    refresh fast on commit
  3  as
  4  select a.rowid dept_rowid
  5       , b.rowid emp_rowid
  6       , a.deptno
  7    from dept a
  8         left join emp b on (a.deptno = b.deptno)
  9  /
  from dept a
       *
ERROR at line 7:
ORA-12054: cannot set the ON COMMIT refresh attribute for the materialized view

Still it cannot fast refresh, because of the ANSI joins. Converting to old-style outer join syntax:

SQL> create materialized view empdept_mv
  2    refresh fast on commit
  3  as
  4  select a.rowid dept_rowid
  5       , b.rowid emp_rowid
  6       , a.deptno
  7    from dept a
  8       , emp b
  9   where a.deptno = b.deptno (+)
 10  /

Materialized view created.

And to prove that it works:

SQL> select * from empdept_mv
  2  /

DEPT_ROWID         EMP_ROWID              DEPTNO
------------------ ------------------ ----------
AAARhmAAEAAAAI/AAB AAARhlAAEAAAAI3AAA         20
AAARhmAAEAAAAI/AAC AAARhlAAEAAAAI3AAB         30
AAARhmAAEAAAAI/AAC AAARhlAAEAAAAI3AAC         30
AAARhmAAEAAAAI/AAB AAARhlAAEAAAAI3AAD         20
AAARhmAAEAAAAI/AAC AAARhlAAEAAAAI3AAE         30
AAARhmAAEAAAAI/AAC AAARhlAAEAAAAI3AAF         30
AAARhmAAEAAAAI/AAA AAARhlAAEAAAAI3AAG         10
AAARhmAAEAAAAI/AAB AAARhlAAEAAAAI3AAH         20
AAARhmAAEAAAAI/AAA AAARhlAAEAAAAI3AAI         10
AAARhmAAEAAAAI/AAC AAARhlAAEAAAAI3AAJ         30
AAARhmAAEAAAAI/AAB AAARhlAAEAAAAI3AAK         20
AAARhmAAEAAAAI/AAC AAARhlAAEAAAAI3AAL         30
AAARhmAAEAAAAI/AAB AAARhlAAEAAAAI3AAM         20
AAARhmAAEAAAAI/AAA AAARhlAAEAAAAI3AAN         10
AAARhmAAEAAAAI/AAD                            40

15 rows selected.

SQL> insert into dept values (50,'IT','UTRECHT')
  2  /

1 row created.

SQL> commit
  2  /

Commit complete.

SQL> select * from empdept_mv
  2  /

DEPT_ROWID         EMP_ROWID              DEPTNO
------------------ ------------------ ----------
AAARhmAAEAAAAI/AAB AAARhlAAEAAAAI3AAA         20
AAARhmAAEAAAAI/AAC AAARhlAAEAAAAI3AAB         30
AAARhmAAEAAAAI/AAC AAARhlAAEAAAAI3AAC         30
AAARhmAAEAAAAI/AAB AAARhlAAEAAAAI3AAD         20
AAARhmAAEAAAAI/AAC AAARhlAAEAAAAI3AAE         30
AAARhmAAEAAAAI/AAC AAARhlAAEAAAAI3AAF         30
AAARhmAAEAAAAI/AAA AAARhlAAEAAAAI3AAG         10
AAARhmAAEAAAAI/AAB AAARhlAAEAAAAI3AAH         20
AAARhmAAEAAAAI/AAA AAARhlAAEAAAAI3AAI         10
AAARhmAAEAAAAI/AAC AAARhlAAEAAAAI3AAJ         30
AAARhmAAEAAAAI/AAB AAARhlAAEAAAAI3AAK         20
AAARhmAAEAAAAI/AAC AAARhlAAEAAAAI3AAL         30
AAARhmAAEAAAAI/AAB AAARhlAAEAAAAI3AAM         20
AAARhmAAEAAAAI/AAA AAARhlAAEAAAAI3AAN         10
AAARhmAAEAAAAI/AAD                            40
AAARhmAAEAAAAI7AAA                            50

16 rows selected.

The ANSI-join syntax restriction is mentioned in point 6 in this blogpost.

Regards, Rob.

于 2009-08-23T14:10:29.853 に答える
1

これは古い投稿です。いいえ、完全な解決策について言及していません。

  1. Oracle doc に記載されているように、外部結合されたテーブルには主キーが必要です。
  2. クエリには他の制約があってはなりません。つまり、WHERE句にフィルタ基準がなく、結合だけがあってはなりません。句にCASE/DECODEステートメントを含めることもできません。、、などは許可されます。SELECTGROUP BYSUM()COUNT()

上記のサンプル例では、主キーが部門テーブルの部門 ID 列に作成されている場合にクエリが機能します。

于 2011-07-08T19:58:29.343 に答える
0

次の手順に従って、DBMS_MVIEW.EXPLAIN_MVIEW を機能させました。 http://www.sqlsnippets.com/en/topic-12884.html

できる:

REFRESH_COMPLETE

次のことができません:

REFRESH_FAST


FROM リスト内の REFRESH_FAST_AFTER_INSERTインライン ビューまたはサブクエリは、このタイプの MV ではサポートされていません


FROM リスト内の REFRESH_FAST_AFTER_INSERTインライン ビューまたはサブクエリは、このタイプの MV ではサポートされていません

リストからのREFRESH_FAST_AFTER_INSERT
ビューまたはサブクエリ

REFRESH_FAST_AFTER_ONETAB_DML
REFRESH_FAST_AFTER_INSERT が無効になっている理由を参照してください

MV_REPORT

REFRESH_FAST_AFTER_ANY_DML
REFRESH_FAST_AFTER_ONETAB_DML が無効になっている理由を参照してください

于 2009-08-21T18:11:59.893 に答える