Oracle误删除表数据后的数据恢复详解
|
数据恢复简单例子 3. 下面我们通过一个例子来具体说明闪回查询的用法 示例
SQLgt; conn /as sysdba
Connected.
SQLgt; drop user lsf cascade;
User dropped.
SQLgt; create user lsf identified by lsf;
User created.
SQLgt; grant connect,resource to lsf;
Grant succeeded.
SQLgt; grant execute on dbms_flashback to lsf;
Grant succeeded.
SQLgt; conn lsf/lsf
Connected.
SQLgt; create table T(id int, name varchar2(20));
Table created.
SQLgt; insert into T values(1,'lsf');
1 row created.
SQLgt; insert into T values(2,'lsf');
1 row created.
SQLgt; insert into T values(3,'lsf');
1 row created.
SQLgt; commit;
Commit complete.
SQLgt; select * from T;
ID NAME
---------- ------------------------------------------------------------
1 lsf
2 lsf
3 lsf
SQLgt; set time on
10:12:50 SQLgt; delete from T where id=1;
1 row deleted.
10:13:02 SQLgt; commit;
Commit complete.
10:13:10 SQLgt; select * from T;
ID NAME
---------- ------------------------------------------------------------
2 lsf
3 lsf
10:13:18 SQLgt; execute DBMS_FLASHBACK.ENABLE_AT_TIME(to_date('2011-04-15 10:12:50','YYYY-MM-DD HH24:MI:SS'));
PL/SQL procedure successfully completed.
10:13:50 SQLgt; select * from T;
ID NAME
---------- ------------------------------------------------------------
1 lsf
2 lsf
3 lsf
10:13:57 SQLgt; execute DBMS_FLASHBACK.DISABLE;
PL/SQL procedure successfully completed.
10:15:48 SQLgt; select * from T;
ID NAME
---------- ------------------------------------------------------------
2 lsf
3 lsf
3.3 使用闪回查询恢复数据
10:16:59 SQLgt; truncate table T;
Table truncated.
10:18:15 SQLgt; select * from T;
no rows selected
10:18:22 SQLgt; insert into T values(1,'lsf');
1 row created.
10:19:42 SQLgt; insert into T values(2,'lsf');
1 row created.
10:19:48 SQLgt; insert into T values(3,'lsf');
1 row created.
10:19:55 SQLgt; insert into T values(4,'lsf');
1 row created.
10:20:07 SQLgt; insert into T values(5,'lsf');
1 row created.
10:20:15 SQLgt; insert into T values(6,'lsf');
1 row created.
10:20:21 SQLgt; commit;
Commit complete.
10:20:26 SQLgt; select * from T;
ID NAME
---------- ------------------------------------------------------------
1 lsf
2 lsf
3 lsf
4 lsf
5 lsf
6 lsf
6 rows selected.
10:20:56 SQLgt; delete T;
6 rows deleted.
10:21:27 SQLgt; commit;
Commit complete.
10:21:40 SQLgt; declare
10:22:29 2 cursor flash_recover is
10:22:43 3 select * from T;
10:22:50 4 t_recode T%rowtype;
10:23:11 5 begin
10:23:14 6 DBMS_FLASHBACK.ENABLE_AT_TIME(to_date('2011-04-15 10:20:56','YYYY-MM-DD HH24:MI:SS'));
10:24:22 7 open flash_recover;
10:24:39 8 DBMS_FLASHBACK.DISABLE;
10:24:59 9 loop
10:25:05 10 FETCH flash_recover into t_recode;
10:25:24 11 EXIT WHEN flash_recover%NOTFOUND;
10:25:45 12 insert into T values(t_recode.id,t_recode.name);
10:26:35 13 end loop;
10:26:39 14 CLOSE FLASH_RECOVER;
10:26:50 15 commit;
10:26:56 16 end;
10:26:58 17 /
PL/SQL procedure successfully completed.
10:27:00 SQLgt; select * from T;
ID NAME
---------- ------------------------------------------------------------
1 lsf
2 lsf
3 lsf
4 lsf
5 lsf
6 lsf
6 rows selected.
我们可以已经恢复了所有的6条纪录,但是由于闪回查询的局限性,有可能不能恢复所有的6条记录,原因就在下面。 4. 局限性
10:27:27 SQLgt; VARIABLE SCN_SAVE NUMBER;
10:32:47 SQLgt; EXECUTE :SCN_SAVE := DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER;
PL/SQL procedure successfully completed.
10:33:24 SQLgt; print SCN_SAVE;
SCN_SAVE
----------
3438420
10:33:41 SQLgt; execute DBMS_FLASHBACK.ENABLE_AT_SYSTEM_CHANGE_NUMBER(:SCN_SAVE);
PL/SQL procedure successfully completed.
10:34:31 SQLgt; select * from T;
ID NAME
---------- ------------------------------------------------------------
1 lsf
2 lsf
3 lsf
4 lsf
5 lsf
6 lsf
6 rows selected.
(编辑:成都站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |

