zoukankan      html  css  js  c++  java
  • Oracle闪回

    在PLSQL开发时,有时候会遇到对表的误删除,其实遇到这种情况不需要紧张,如果问题较大,请DBA帮忙,如果只是小问题,只需自己处理,利用flashback闪回操作即可,可将表进行恢复

    在删除表时,系统一般都是表放入回收站中,并没有完全进行删除,因此,只需从回收站中进行恢复就可以了,原理和Window中的回收站一样,但是一旦将回收站中的资料再进行删除,这个就很难恢复了,只能向DBA求救

    1. 回收站的概念

    回收站,是一个虚拟的容器,用于存放所有被删除的对象。

    实质上说,对于一个对象的删除,数据库仅仅是简单的重命名操作。

    数据库参数recyclebin设置为on.(即默认设置)。参数recyclebin为on,则表示把Drop的对象放入回收站。为off,则表示直接删除对象而不放入回收站。

    2. 查看recyclebin值命令

    SQL> show parameter bin;

    NAME                         TYPE       VALUE

    -----------------------------------------------

    recyclebin                   string      on

    3. 在系统或会话级别中修改参数recyclebin值的命令为

    SQL>alter system set recyclebin = on|off;

    SQL>alter session set recyclebin = on|off;

    4. 对回收站的相关操作

    查看回收站的相关信息视图有:recyclebin/user_recyclebin/dba_recyclebin.

    手动清除回收站的信息为:purge recyclebin(或purge table original_name);

     
    --查看被删除的表是否进去了回收站
    SELECT *
      FROM dba_recyclebin dr
     WHERE dr.original_name LIKE 'CUX%' ;
     
     object_name为被删除表修改后的名称,可直接查询SELECT *   FROM  object_name
     
     
    通过flashback对表进行恢复
    FLASHBACK TABLE   cux.xxxxxx TO BEFORE DROP
    若表在被恢复前被重新创建,则 FLASHBACK TABLE   cux.xxxxxx TO BEFORE DROP  RENAME TO   xxxxxx1
     
     
    --查看是否恢复成功
    select * from  cux.xxxxxx 或者
    select * from  cux.xxxxxx1
     
     
     
     
    --查看索引
    SELECT *
      FROM user_recyclebin dr
     WHERE dr.original_name LIKE 'CUX%';
     
          object_name为现索引名
     
     
    --恢复索引
    alter index "BIN$/KUwk5MzNTfgQDQKbgxFbw==$0" rename to ind_creation_date
  • 相关阅读:
    beta冲刺————第二天(2/5)
    beta冲刺————第一天(1/5)
    个人作业——软件产品案例分析
    c++第七次作业____最后的总结
    计算器图形界面
    object-oriented second work
    第五次作业(文件处理)
    object-oriented first work
    第四次作业--计算器简单计算
    新的Calculator的规范作业
  • 原文地址:https://www.cnblogs.com/wang-chen/p/5915594.html
Copyright © 2011-2022 走看看