ORACLE 利用SCN恢复误delete的表

--kg是误删除的表
SQL> select count(*) from  kg;
  COUNT(*)
----------
    820861
SQL> delete from kg;
820861 rows deleted
SQL> commit;
Commit complete
SQL> select count(*) from kg;
  COUNT(*)
----------
         0
SQL> rollback;
Rollback complete
SQL> select count(*) from kg;
  COUNT(*)
----------
         0
--kg被删除且已经提交。

--查询此时数据库的SCN
SQL> select dbms_flashback.get_system_change_number from dual;
GET_SYSTEM_CHANGE_NUMBER
------------------------
                 4915780
SQL> select count(*) from kg as of scn 4915780;
  COUNT(*)
----------
         0
--创建表howard存放数据库的SCN
SQL> create table howard(count int,scn int);
Table created
SQL> DECLARE
     i INT:=4915600;
     BEGIN
        FOR i IN 4915600..4915782 LOOP
          INSERT INTO howard( SCN) VALUES (i );
          UPDATE howard SET COUNT =( SELECT COUNT(*) FROM kg AS OF SCN i) WHERE SCN= i;
        END LOOP ;
     END ;
     /
SQL> SELECT * FROM howard
SQL> /

                                  COUNT                                     SCN
--------------------------------------- ---------------------------------------
                                 820861                                 4915704
                                 820861                                 4915705
                                 820861                                  4915706
                                      0                                 4915707
                                      0                                 4915708
                                      0                                 4915709

--得到删除前数据库的SCN,恢复表数据
SQL>  select count(*) from kg  as of scn 4915706;
  COUNT(*)
----------
    820861
SQL> select count(*) from kg  as of scn 4915707;
  COUNT(*)
----------
         0
SQL>  insert into kg select * from kg as of scn 4915706;
820861 rows inserted
SQL> drop table howard;
Table dropped
SQL> commit;
Commit complete

你可能感兴趣的:(oracle)