أوراكل :تتحقق الرأي لا يعمل عند استخدام اليسار الانضمام

StackOverflow https://stackoverflow.com/questions/1312980

سؤال

أريد إنشاء تتحقق من اليسار الانضمام من 2 الجداول.ومع ذلك ما يلي يعطيني خطأ:

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

ORA-12054:لا يمكن تعيين على ارتكاب تحديث سمة تتحقق الرأي

ومع ذلك الأعمال التالية:

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

هل من أحد لديه أفكار لماذا يحدث هذا.

Thx للمساعدة

هل كانت مفيدة؟

المحلول

هناك نوعان من الشروط التي لا ترضى أن تجعل تتحقق الرأي تحديث سريع.أول واحد هو أنك لم تحدد rowid الأعمدة من كل طاولة المعنيين.والثاني هو غير الشرعيين تقييد:ANSI-ينضم إلى غير معتمدة.

هنا مثال مع قسم يجري table_1, الاسم المستعار و EMP يجري table_2 الملقب ب:

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

الذي يحاكي الوضع الخاص بك.أولا إضافة rowid هو:

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

لا تزال لا يمكن تحديث سريع بسبب ANSI ينضم.تحويل الطراز القديم الخارجي الانضمام إلى الجملة:

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.

وإثبات أن يعمل:

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.

ANSI-الانضمام إلى جملة من القيود المذكورة في النقطة 6 في هذا blogpost.

التحيات ، روب.

نصائح أخرى

لأن هذا هو وظيفة قديمة؛ لم يذكر الحل الكامل.

  1. يجب أن يكون الجدول الخارجي الذي ينضم إلى مفتاح أساسي كما هو مذكور في Oracle Doc.
  2. يجب ألا يكون الاستعلام أي قيود أخرى، فلا ينبغي أن يكون لديك أي معايير مرشح في WHERE جملة، فقط ينضم؛ ولا يمكن أن يكون CASE/DECODE البيانات في SELECT بند؛ GROUP BY, SUM(), COUNT() ومثل هذه المسموح بها، رغم ذلك.

في المثال أعلاه، سيعمل الاستعلام إذا تم إنشاء مفتاح أساسي في جدول القسم على عمود معرف DEPT.

اتبع الإرشادات التالية لجعل عمل dbms_mview.explain_mview:http://www.sqlsnippets.com/en/topic-12884.html.

قادر على:

اكتمال التحديث

غير قادر على:

Refresh_fast.

Refresh_fast_after_insert.
عرض مضمن أو استعلام فرعي من القائمة غير مدعومة لهذا النوع MV

Refresh_fast_after_insert.
عرض مضمن أو استعلام فرعي من القائمة غير مدعومة لهذا النوع MV

Refresh_fast_after_insert.
عرض أو Sacquery في القائمة

Refresh_fast_after_onetab_dml.
راجع السبب في تعطيل Refresh_Fast_After_Insert

mv_report.

Refresh_Fast_After_Any_DML.
راجع السبب في تعطيل Refresh_Fast_After_OnetAb_dml

مرخصة بموجب: CC-BY-SA مع الإسناد
لا تنتمي إلى StackOverflow
scroll top