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
  • 相关阅读:
    bzoj2434: [Noi2011]阿狸的打字机
    bzoj2830: [Shoi2012]随机树
    题解,作业*2
    bzoj1901: Zju2112 Dynamic Rankings
    luogu P4178 Tree
    CF1042C Array Product 分类讨论+贪心
    CF946D Timetable 动态规划
    CF597C Subsequences 树状数组 + 动态规划
    CF912D Fishes 期望 + 贪心
    bzoj 4321 queue2 dp
  • 原文地址:https://www.cnblogs.com/wang-chen/p/5915594.html
Copyright © 2011-2022 走看看