flashback table 出現 ORA-08194: 在實體化檢視上不允許閃回表操作

tolilong發表於2013-03-27
今天flashback table的時候出現了ORA-08194錯誤,臨時辦法將錯誤操作前的資料儲存到另外一張表上面。
下面是自己測試的筆記。
SQL> create table tt (id int,name varchar2(20));

Table created.
[@more@]

SQL> insert into tt values(1,'bruce');

1 row created.

SQL> commit;

Commit complete.

SQL> create materialized view tt_mv as select * from tt;

Materialized view created.
SQL> select dbms_flashback.get_system_change_number() from dual;

DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER()
-----------------------------------------
34274375
SQL> insert into tt values(2,'bruce1');

1 row created.

SQL> commit;

Commit complete.

SQL> select * from tt;

ID NAME
---------- ----------------------------------------
1 bruce
2 bruce1

SQL> select * from tt_mv;

ID NAME
---------- ----------------------------------------
1 bruce
SQL> flashback table tt to scn 34274375;
flashback table tt to scn 34274375
*
ERROR at line 1:
ORA-08194: 在實體化檢視上不允許閃回表操作
由於user的錯誤操作,建立了mv的table上不能flashback,
此時為了保護正確的資料,
需要將create table tt_new儲存誤操作前的資料
SQL> create table tt_new as select * from tt as of scn 34274375;

Table created.

SQL> select * from tt_new
2 ;

ID NAME
---------- ----------------------------------------
1 bruce

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

相關文章