zoukankan      html  css  js  c++  java
  • 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  表名也无法恢复,因为这两个操作执行后,不会把数据放入到回收站中,而是直接删除。

  • 相关阅读:
    c++虚继承
    linux常用命令大全
    数据库三大范式最通俗解释
    PG数据库空间大小及数据库对象占用空间大小
    Oracle表分区详解
    Excel数据导入PG库,字符串正则表达式
    Oracle 执行计划
    ASP.NET MVC5框架揭秘 学习笔记01
    .NET简单学习
    蓝桥杯_算法训练_ALGO10_集合运算
  • 原文地址:https://www.cnblogs.com/gdpuzxs/p/6925017.html
Copyright © 2011-2022 走看看