SQL> create table flash_version as select * from user_objects;
SQL> SELECT DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER FROM DUAL;
GET_SYSTEM_CHANGE_NUMBER
------------------------
122693629913
SQL> update flash_version set object_id=object_id+100;
1 row updated.
SQL> commit;
Commit complete.
SQL> delete from flash_version;
1 row deleted.
SQL> commit;
Commit complete.
SQL> insert into flash_version select * from user_objects where rownum<2;
1 row created.
SQL> commit;
Commit complete.
SQL> SELECT DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER FROM DUAL;
GET_SYSTEM_CHANGE_NUMBER
------------------------
122693629931
SQL> SELECT VERSIONS_STARTSCN,VERSIONS_ENDSCN,VERSIONS_OPERATION, VERSIONS_XID FROM flash_version versions between scn 122693629913 and 122693629931;
VERSIONS_STARTSCN VERSIONS_ENDSCN V VERSIONS_XID
-------------------- -------------------- - ----------------
122693629929 I 14001300C7F70900
122693629925 D 18002200B69E0100
VERSIONS_STARTSCN VERSIONS_ENDSCN V VERSIONS_XID
-------------------- -------------------- - ----------------
122693629920 122693629925 U 1900130089AE0100
122693629920
由此可以看到每个SCN是什么操作,根据对应的SCN,那么就可以闪回到某一个特定的SCN。
flashback query条件:要使用该功能,那么必须启用自动撤销管理表空间。
undo_management string AUTO --就是这个参数,不过从9I这个都是默认的
flashback table使用:其实就是误删了表以后,想再找回该表
条件:除了之前的flashback query条件以外,还需要打开recyclebin,也就是大家熟悉的回收站,有点类似windows下面的那个回收站举例:
SQL> show parameter recyclebin;
NAME TYPE VALUE
------------------------------------ -------------------------------- ------------------------------
recyclebin string onSQL> select table_name from user_tables;
TABLE_NAME
------------------------------
TB1
SQL> drop table tb1;
Table dropped.
SQL> SELECT OBJECT_NAME,ORIGINAL_NAME,TYPE,DROPTIME from RECYCLEBIN;
OBJECT_NAME ORIGINAL_NAME TYPE DROPTIME
------------------------------ -------------------------------- ------------------------- -------------------
BIN$2u57wKmp6GHgQKjAIgF10w==$0 TB1 TABLE 2013-04-22:15:23:37
SQL> select table_name from user_tables;
TABLE_NAME
------------------------------
FLASH_VERSION
TBL_ORACLE_FDW
SQL> flashback table tb1 to before drop;
Flashback complete.
SQL> select table_name from user_tables;
TABLE_NAME
------------------------------
TB1
FLASH_VERSION
TBL_ORACLE_FDW
这里有一个注意的是如果删除的表中有索引,那么这个索引恢复以后,名字还是recyclebin中的名字,这个是为了避免名字冲突,所以恢复以后可以用alter index "xxxxxxxxxxx" rename to xxxx;
已经存在表的恢复:
SQL> drop table tb1;
Table dropped.
SQL> create table tb1 (a number(10));
Table created.
SQL> SELECT OBJECT_NAME,ORIGINAL_NAME,TYPE,DROPTIME from RECYCLEBIN;
OBJECT_NAME ORIGINAL_NAME TYPE DROPTIME
------------------------------ -------------------------------- ------------------------- -------------------
BIN$2u57wKmq6GHgQKjAIgF10w==$0 TB1 TABLE 2013-04-22:15:31:00
SQL> flashback table tb1 to before drop;
flashback table tb1 to before drop
*
ERROR at line 1:
ORA-38312: original name is used by an existing object
SQL> flashback table tb1 to before drop rename to tb2;
Flashback complete.
SQL> select table_name from user_tables;
TABLE_NAME
------------------------------
TB2
FLASH_VERSION
TB1
还可以从多次删除中恢复:这里不再举例,理解即可,通过一下命令即可指定恢复某一个删除的表
FLASHBACK TABLE "BIN$2u57wKmp6GHgQKjAIgF10w==$0" TO BEFORE DROP;
另外flashback table 还支持从undo中恢复数据,使用起来和之前介绍的flashback query类似:
使用起来很简单,如之前的:select * from tb1 as of scn/timestamp xxx; 替换为 flashback table tb1 to scn/timestamp xxx;
当然这有一个好处就是比如要恢复一个做过复杂更新或者删除的表,flashback table当然是首选,如果用flash query,那么需要分别判断修改的记录并做不同的处理。
注意点:
基于UNDO的恢复,需要表ENABLE ROW MOVEMENT,这个属性用来控制是否允许修改的列值所造成的记录移动。如果是disable状态,那么记录列值有移动操作时,更新语句会触发ORA-08189错误。可以通过查询USER_TABLES的ROW_MOVEMENT查看属性。
ALTER TABLE xxxxxx ENABLE/DISABLE ROW MOVEMENT; --通过该语句修改属性