flashback table 出現 ORA-08194: 在實體化檢視上不允許閃回表操作
今天flashback table的時候出現了ORA-08194錯誤,臨時辦法將錯誤操作前的資料儲存到另外一張表上面。
下面是自己測試的筆記。
SQL> create table tt (id int,name varchar2(20));Table created.
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
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
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: 在實體化檢視上不允許閃回表操作
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
Table created.
SQL> select * from tt_new
2 ;
ID NAME
---------- ----------------------------------------
1 bruce
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/24237320/viewspace-1060338/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 對錶誤操作的閃回恢復--flashback_transaction_query檢視
- ORACLE 閃回檢視v$flashback_database_log/statOracleDatabase
- 【Flashback】使用檢視快速獲得Flashback Query閃回查詢資料
- 表閃回操作及解決閃回表時出現的ORA-08189故障
- 利用flashback閃回表和資料
- [Flashback]Flashback Database閃回資料庫實驗Database資料庫
- 【Flashback】Flashback Drop閃回刪除功能實踐
- oracle 閃回 flashbackOracle
- 【Flashback】Flashback Database閃回資料庫功能實驗Database資料庫
- 【Flashback】Flashback Database閃回資料庫功能實踐Database資料庫
- Flashback閃回技術
- Flashback Drop閃回刪除功能實踐
- 閃回之 回收站、Flashback Drop (table、index、trigger等)Index
- flashback query閃回資料
- Flashback Query閃回查詢
- Oracle 閃回特性(FLASHBACK DATABASE)OracleDatabase
- 使用正則不允許對整表進行操作
- [閃回特性之閃回版本查詢]Flashback Version Query
- 使用dbms_flashback工具包實現閃回查詢功能
- 閃回之 Flashback Query (dml表、過程、函式、包等)、Flashback version Query函式
- 【Flashback】使用Flashback Drop技術閃回被DROP表的指定版本資料
- 【Flashback】10G的新特性“閃回表”清除方法
- 閃回資料庫時間視窗(flashback database window)資料庫Database
- Flashback Database 閃回資料庫Database資料庫
- 【Mysql】mysql閃回flashback-5.7MySql
- 【Flashback】Flashback Table功能實踐
- 【Flashback】啟用Flashback Database閃回資料庫功能Database資料庫
- 影響flashback table的操作!
- 閃回表、閃回查詢
- FlashBack總結之閃回資料庫與閃回刪除資料庫
- 【Flashback】使用閃回功能快速恢復使用者的誤操作
- Oracle閃回技術--Flashback Version QueryOracle
- flashback閃回技術應用解析
- 開啟oracle的flashback閃回功能Oracle
- Flashback_oracle閃回功能的使用Oracle
- 閃回版本查詢(Flashback Version Query)
- 閃回區滿的處理 - flashback
- 閃回技術二:閃回表