Oracle闪回机制
Posted gdpuzxs
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Oracle闪回机制相关的知识,希望对你有一定的参考价值。
最近学习oracle的时候,无意中看到oracle的闪回技术flashback,原来oracle在delete数据或者drop的时候,不是直接删除,而是跟windows一样,先把数据放入到回收站中。
select * from user_recyclebin
可以查看user_recyclebin,可以看到最近删除的表格以及索引,如下:
下面我们用一个例子测试一下:删除表数据,然后测试数据是否可以被恢复。
select * from testemp1
初始数据如下:
现在我们删除一下deptno=10的数据,如下:
delete from TESTEMP1 where deptno=10
查看数据如下:
现在数据已经被删除了,我们利用oracle的闪回技术进行恢复,如下:
(1)开启行移动功能,否则报错,如下:
alter table TESTEMP1 enable row movement
(2)执行闪回操作,如下:
flashback table testemp1 to timestamp to_timestamp(\'2017/5/31 16:15:52\',\'yyyy-mm-dd hh24:mi:ss\');
(3)查看表数据,如下:
下面我们直接删除表格drop,如下:删除表格,测试表格是否可恢复。
drop table TESTEMP1
查看testemp1,报错如下:
(2)查看垃圾箱,如下:有一条drop记录。
select * from user_recyclebin order by droptime desc
(3)执行闪回,如下:被删除的表格又恢复了。
flashback table testemp1 to before drop
下面我们删除表的结构,删除一列sal,然后测试一下表结构以及数据能否被恢复? 如下:
查看回收站,发现没有任何记录,如下:
执行闪回sql报错,如下:
flashback table testemp1 to timestamp to_timestamp(\'2017-05-31 16:40:00\',\'yyyy-mm-dd hh24:mi:ss\');
总结:oracle的flashback功能,如果删除数据或者直接drop table是可以恢复数据的。如果删除表结构或者先执行删除数据后面又执行了删除表结构,使用flashback是无法恢复的。另外,使用 drop table 表名 purge 或 TRUNCATE TABLE 表名也无法恢复,因为这两个操作执行后,不会把数据放入到回收站中,而是直接删除。
以上是关于Oracle闪回机制的主要内容,如果未能解决你的问题,请参考以下文章