方便起见一般:执行如下即可不用往下看:

 ① 启用行移动功能

 alter table tbl_a  enable row movement;

 ② 闪回表数据到某个时间点

 flashback table tbl_a   to timestamp to_timestamp('2013-07-19 15:10:00','yyyy-mm-dd hh24:mi:ss');

 详解:

 利用ORACLE的闪回功能恢复数据

 一、 闪回表数据

     从9i开始,Oracle提供了闪回(FLASHBACK)功能。使用FLASHBACK TABLE语句从撤消段中(undo segment)读取该表的过去映像,并利用Oracle9i中引入的回闪查询重建表行。UNDO_RETENTION给出了闪回支持的最小时间。也就是说,FLASHBACK最少可以支持UNDO_RETENTION给出的时间,如果系统比较闲,则可以闪回更长的时间。(当然,如果回滚表空间的空间分配不足,当系统处于忙时,有可能重用还没有达到UNDO_RETENTION时间限制的数据的空间)。使用闪回的一个前提是表不能进行DDL操作。不但不能对DDL操作进行回闪,而且,也无法闪回到DDL操作以前的数据了。

 SQL> select * from v$version;

 BANNER

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

 Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Prod

 PL/SQL Release 10.2.0.1.0 - Production

 CORE    10.2.0.1.0      Production

 TNS for 32-bit Windows: Version 10.2.0.1.0 - Production

 NLSRTL Version 10.2.0.1.0 – Production

 --获得系统变更号

 C:\Documents and Settings\linyuefeng>sqlplus /nolog

 SQL*Plus: Release 10.2.0.1.0 - Production on 星期四 10月 26 20:41:28 2006

 Copyright (c) 1982, 2005, Oracle.  All rights reserved.

 SQL> conn scott/scott@ora10g;

 已连接。

 SQL> var scn number

 SQL> exec :scn :=dbms_flashback.get_system_change_number

 PL/SQL 过程已成功完成。

 SQL> print scn

        SCN

 ----------

 914958

 SQL> select count(*) from emp;

   COUNT(*)

 ----------

         14

 SQL> delete from emp;

 已删除14行。

 SQL> select count(*) from emp;

   COUNT(*)

 ----------

          0

 SQL> commit;

 提交完成。

 SQL> select count(*) from emp as of scn :scn;

   COUNT(*)

 ----------

         14

 SQL> flashback table emp to scn :scn;

 flashback table emp to scn :scn

                 *

 第 1 行出现错误:

 ORA-08189: 因为未启用行移动功能, 不能闪回表

 SQL> alter table emp enable row movement;

 表已更改。

     这个命令的作用就是允许ORACLE修改分配给行的rowid。在ORACLE中,插入一行时就会为它分配一个rowid,而且这一行永远拥有这个rowid。闪回表处理时会对EMP表完成DELETE 操作,并且重新插入行,这样就会为这些行分配一个新的rowid。要支持闪回功能就必须允许ORACLE执行这个操作。

 SQL> flashback table emp to scn :scn;

 闪回完成。

 SQL> select count(*) from emp;

   COUNT(*)

 ----------

         14

 ---也可以通过时间进行闪回

 SQL> select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss')  TIME from dual;

 TIME

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

 2006-10-26 20:55:48

 SQL> select count(*) from emp;

   COUNT(*)

 ----------

         14

 SQL> delete from emp;

 已删除14行。

 SQL> commit;

 提交完成。

 SQL> flashback table emp to timestamp to_date('2006-10-26 20:55:48','yyyy-mm-dd

 hh24:mi:ss');

 闪回完成。

 SQL> select count(*) from emp;

   COUNT(*)

 ----------

         14

 二、 闪回删除的表

     flashback drop特性从Oracle10g开始才有的,这个新特性,允许你从当前数据库中恢复一个被drop了的对象。在执行drop操作时,现在Oracle不是真正删除它,而是将该对象自动将放入回收站(一个虚拟的容器,用于存放所有被删除的对象)。对于一个对象的删除,ORACLE的操作仅仅就是简单的重令名而已。

     在回收站中,被删除的对象将占用创建时的同样的空间,可以利用flashback功能来恢复它, 这个就是flashback drop功能。

 SQL> create table emp_test as select * from emp;

 Table created

 SQL> drop table emp_test;

 Table dropped

     当一个表被删除并移动到"回收站"中,它的名字要进行一些转换。这样的目的显而易见是为了避免同类对象名称的重复。

 SQL> select owner,object_name,original_name,DROPTIME from dba_recyclebin order by droptime;

 OWNER  OBJECT_NAME                       ORIGINAL_NAME      DROPTIME

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

 SCOTT   BIN$rtpdTNe6SIysmO+ZB0t3aQ==$0    EMP_TEST          2006-10-26:22:23:06

 SQL> create table emp_test as select * from emp;

 Table created

 SQL> drop table emp_test;

 Table dropped

 SQL> select owner,object_name,original_name, DROPTIME from dba_recyclebin order by droptime;

 OWNER  OBJECT_NAME                     ORIGINAL_NAME   DROPTIME

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

 SCOTT  BIN$rtpdTNe6SIysmO+ZB0t3aQ==$0  EMP_TEST        2006-10-26:22:23:06

 SCOTT  BIN$roQhkx6tQneThvaRlsjrhw==$0  EMP_TEST        2006-10-26:22:23:50

 --使用flashback table 进行恢复,默认恢复最近删除的表

 SQL> flashback table emp_test to before drop;

 Done

 SQL> select owner,object_name,original_name,DROPTIME from dba_recyclebin order by droptime;

 OWNER   OBJECT_NAME                      ORIGINAL_NAME   DROPTIME

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

 SCOTT   BIN$rtpdTNe6SIysmO+ZB0t3aQ==$0   EMP_TEST        2006-10-26:22:23:06

 --也可以指定表名进行恢复

 SQL> flashback table "BIN$rtpdTNe6SIysmO+ZB0t3aQ==$0" to before drop;

 flashback table "BIN$rtpdTNe6SIysmO+ZB0t3aQ==$0" to before drop

 ORA-38312: 原始名称已被现有对象使用

     此时被恢复的表名称仍然采用以前的名字,我们之前已经恢复一次EMP_TEST,所以现在恢复就出现了重名,不过可以为其指定新的名字。

 SQL> flashback table "BIN$rtpdTNe6SIysmO+ZB0t3aQ==$0" to before drop rename to emp_test2;

 Done

 SQL> select table_name from user_tables where table_name like '%EMP_TEST%';

 TABLE_NAME

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

 EMP_TEST

 EMP_TEST2

 --删除回收站里的对象,不能使用DROP命令进行删除,必须使用PURGE命令

 SQL> drop table emp_test;

 Table dropped

 SQL> drop table emp_test2;

 Table dropped

 SQL> select owner,object_name,original_name,DROPTIME from dba_recyclebin order by droptime;

 OWNER   OBJECT_NAME                      ORIGINAL_NAME    DROPTIME

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

 SCOTT   BIN$M4Q0Pb94SOWSFGarOpI5Og==$0   EMP_TEST         2006-10-26:22:46:07

 SCOTT   BIN$7P+osQdjSs+5CcSXBc0NAA==$0   EMP_TEST2        2006-10-26:22:46:10

 SQL> drop table "BIN$M4Q0Pb94SOWSFGarOpI5Og==$0";

 drop table "BIN$M4Q0Pb94SOWSFGarOpI5Og==$0"

 ORA-38301: 无法对回收站中的对象执行 DDL/DML

 SQL> purge table "BIN$M4Q0Pb94SOWSFGarOpI5Og==$0";

 Done

 SQL> select owner,object_name,original_name,DROPTIME from dba_recyclebin order by droptime;

 OWNER    OBJECT_NAME                     ORIGINAL_NAME    DROPTIME

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

 SCOTT    BIN$7P+osQdjSs+5CcSXBc0NAA==$0  EMP_TEST2        2006-10-26:22:46:10

 --删除整个回收站里的对象

 SQL> purge recyclebin;

 Done

 SQL> select owner,object_name,original_name,DROPTIME from dba_recyclebin order by droptime;

 OWNER    OBJECT_NAME                     ORIGINAL_NAME    DROPTIME

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

 未选定行

oracle_利用闪回功能恢复数据的更多相关文章

  1. 利用闪回查看Oracle表历史时刻数据

    利用闪回查看Oracle表历史时刻数据 1.查看表历史时刻数据 select * from tab_test AS OF TIMESTAMP to_timestamp('20140917 10:00: ...

  2. 【Oracle】Oracle 10g利用闪回挽救误删的数据

    我们在开发和运维过程中,经常遇到数据被误删除的情况.无论是在应用开发中的Bug,还是修改数据的时候,如果提交了错误数据修改结果,会带来很多问题.一般来说,一旦提交commit事务,我们是不能获取到之前 ...

  3. Oracle 中利用闪回查询确定某表在某时间点之后的修改内容,并恢复至该时间点

    Oracle 中利用闪回查询确定某表在某时间点之后的修改内容: 1.查看 DELETE 及 UPDATE 操作修改的数据: SQL> SELECT * FROM tab AS OF TIMEST ...

  4. 【DG】利用闪回数据库(flashback)修复Failover后的DG环境

    利用闪回数据库(flashback)修复Failover后的DG环境 1.1  BLOG文档结构图 1.2  前言部分 1.2.1  导读和注意事项 各位技术爱好者,看完本文后,你可以掌握如下的技能, ...

  5. Oracle 闪回 找回数据的实现方法

    Oracle 闪回 找回数据的实现方法 闪回技术是Oracle强大数据库备份恢复机制的一部分,在数据库发生逻辑错误的时候,闪回技术能提供快速且最小损失的恢复.这篇文章主要介绍了Oracle 闪回 找回 ...

  6. Flashback Version Query、Flashback Transaction Query快速闪回细粒度数据

    Flashback Version Query 闪回版本查询 使用Flashback Version Query  返回在指定时间间隔或SCN间隔内的所有版本,一次commit命令就会创建一个版本. ...

  7. Oracle 闪回 找回数据

    使用闪回技术,实现基于磁盘上闪回恢复区的自动备份与还原. 一.恢复表对象 1.创建学生表 create table STUDENT ( idno INTEGER, name VARCHAR2(30), ...

  8. oracle flashback data archive闪回数据归档天坑之XID重用导致闪回查询数据重复

    我们有个系统使用了Oracle flashback data archive闪回数据归档特性来作为基于时间点的恢复机制,在频繁插入.更新期间发现SYS_FBA_HIST_NNNN表中的XID被两个事务 ...

  9. binlog2sql闪回恢复数据

    用途: .数据快速回滚 .从binlog生成标准sql 使用限制: .必须设置binlog_format=ROW .binlog_row_image=full,该参数默认为FULL .恢复用户拥有的最 ...

随机推荐

  1. 【程序员联盟】官网上线啦!coderunity.com

    内容简介 欢天喜地,[程序员联盟]官网上线咯(此处应该有鸡蛋丢过来...) [程序员联盟]官网 大家也许会问:“这几天小编都没出文章,跑哪里happy去啦?是不是偷懒去了?” 小编:“臣妾冤枉啊.” ...

  2. POJ3623:Best Cow Line, Gold(后缀数组)

    Description FJ is about to take his N (1 ≤ N ≤ 30,000) cows to the annual"Farmer of the Year&qu ...

  3. EL与JSTL注意事项汇总

    EL使用表达式(5一个 问题) JSTL使用标签(5问题) 什么是EL.它可以用做? EL全名Expression Language在JSP使用页面 格公式${表达式} 样例${requestScop ...

  4. ASP.NET自定义控件组件开发 第五章 模板控件开发

    原文:ASP.NET自定义控件组件开发 第五章 模板控件开发 第五章 模板控件开发 系列文章链接: ASP.NET自定义控件组件开发 第一章 待续 ASP.NET自定义控件组件开发 第一章 第二篇 接 ...

  5. css3 shadow为了实现各种漂亮的阴影效果

    <!DOCTYPE html> <head> <meta http-equiv="Content-Type" content="text/h ...

  6. 玩转Web之Jsp(一)-----jsp中的静态包含(<%@include file="url"%>)与动态包含(<jsp:include>)

    在jsp中include有两种形式,其中<%@include file="url"%>是指令元素,<jsp:include page="" f ...

  7. kettle 4.4源代码分析Transformation

    1.1. 相关的类和接口 1.1.1. JobEntryTrans 实现了JobEntryInterface的execute()方法,被job运行.由JobEntryTrans实例化Trans,并运行 ...

  8. android 联系数据库

    联系人数据库学习 2011-10-31(这是android2.3在接触db) 简单介绍 Android中联系人的信息都是存储在一个叫contacts2.db的数据库中.该数据库的路径是:/data/d ...

  9. 关于查看文件size

    public static long getTotalSize(String device) { StatFs sf = new StatFs (device); //long totalblocks ...

  10. iOS_20_微博的骨架结构

    最后效果图: BeyondViewController.m // // BeyondViewController.m // 20_帅哥no微博 // // Created by beyond on 1 ...