oracle闪回(flashback)的部分实用操作(彻底删除的除外)

一、数据delete并且commit提交之后的闪回

(一):根据时间来恢复:
1、查询数据库当前时间(目的是为了检查数据库时间是否与你电脑时间相近,避免时间不同而将数据恢复到错误时间点)
select  to_char(sysdate,‘yyyy-mm-dd hh24:mi:ss‘) from dual;
2、查询删除数据时间点之前的数据
select * from 表名 as of timestamp to_timestamp(‘2018-08-11 16:12:11‘,‘yyyy-mm-dd hh24:mi:ss‘);
(若没有数据 ,将时间继续提前)
3、恢复数据(激动人心的时刻)
flashback table 表名 to timestamp to_timestamp(‘2018-08-11 16:12:11‘,‘yyyy-mm-dd hh24:mi:ss‘);
但是也可能会出现问题,比如报错:ORA-08189:未启用行移动功能,不能闪回表,不要怕,这个很简单;
alter table 表名 enable row movement;
然后再次执行上面SQL即可;
大功告成,数据恢复成功;

实例:

1、创建测试数据:

select * from test_tmp;

2、删除IDS=3的数据并提交

delete from test_tmp where ids = 3;
commit;

3、查找删除数据时间点之前的数据(操作delete之前的时间)

select to_char(sysdate,‘yyyy-mm-dd hh24:mi:ss‘) from dual;--2018-11-09 16:34:32     --查看当前时间(往前推)

select * from test_tmp as of timestamp to_timestamp(‘2018-11-09 16:30:00‘,‘yyyy-mm-dd hh24:mi:ss‘);  --取一个delete之前的数据(原则离你删除最近的时间,防止其他人的操作数据库增删改发生问题)

ps(还有一个简单的方法就是用plsql时,你可以按ctrl+e查看操作历史,这样更为精确,时间选取在你delete和上一条dml语句之间,如下就可以选取2018/11/9 17:27:09前一点的数据,闪回前查看下数据)

select * from test_tmp as of timestamp to_timestamp(‘2018-11-09 17:27:00‘,‘yyyy-mm-dd hh24:mi:ss‘);--查看这个时间点的数据

4、最后闪回数据

flashback table test_tmp to timestamp to_timestamp(‘2018-11-09 17:27:00‘,‘yyyy-mm-dd hh24:mi:ss‘);

若报错:ORA-08189:未启用行移动功能,不能闪回表先执行下下面语句再闪回

alter table 表名 enable row movement;
alter table 表名 disable row movement;  --关闭

ps(将row movement设置为enable,有可能发生行的物理移动,行的rowid会变化,某一行更新时,如果更新的是分区列,并且更新后的列值不属于原来的这个分区,如果开启了这个选项,就会把这行从这个分区中delete掉,并加到更新后所属的分区。相当于一个隐式的delete+insert,但是不会触发insert/delete触发器。如果没有开启这个选项,就会在更新时报错。

(二):根据数据库SCN恢复数据
1、查询当前数据库SCN号
select current_scn from v$database;(不能执行的话,切换到sys用户或system用户查询)

 
查询到的当前值为:759447476367
2、缩小SCN号查询被删除表数据(若无数据继续缩小SCN,由于数据库操作不止一人,SCN号变化比较多,可以多缩小几个号)
select * from 表名 as of scn 759447472000;
select * from test_tmp as of scn 759447472000;
3、恢复数据
flashback table test_tmp to scn 759447472000;
恢复完成。若报错:ORA-08189:未启用行移动功能,不能闪回表;结果方案同上。

建议:用方案(一)

二、表被drop掉后闪回

1、drop表
drop table test_bak;
2、闪回表
flashback table test_bak to before drop;

(注:drop table test_bak purge;此操作无法闪回,因为已经直接清空了回收站)

(其他后续补充)

原文参考:https://blog.csdn.net/qq_35052774/article/details/52184164

原文参考:https://blog.csdn.net/rockpk008/article/details/38504931

原文地址:https://www.cnblogs.com/shenjie0622/p/9936000.html

时间: 2024-08-02 22:35:10

oracle闪回(flashback)的部分实用操作(彻底删除的除外)的相关文章

Oracle 闪回 flashback

闪回:修复逻辑错误,从当前的点往回退 1.闪回有专门的闪回日志,存放在FIA中,但是只有闪回数据库会用到 2.如果做全数据库的闪回,相当于一次不完全恢复 基于时间点的闪回 SQL> flashback table t_wh_prodlib to timestamp to_timestamp('2015-03-03 12:10:07', 'yyyy-mm-dd hh24:mi:ss'); 将数据库闪回到20150303 12:10:07 如果基于时间点的闪回报错 ERROR at line 1:

Oracle 闪回特性(FLASHBACK DATABASE)

--===================================== -- Oracle 闪回特性(FLASHBACK DATABASE) --===================================== 闪回技术通常用于快速简单恢复数据库中出现的认为误操作等逻辑错误,从闪回的方式可以分为基于数据库级别闪回.表级别闪回.事务 级别闪回,根据闪回对数据的影响程度又可以分为闪回恢复,闪回查询.闪回恢复将修改数据,闪回点之后的数据将全部丢失.而闪回查询则可 以查询数据被DML的

2.Oracle 闪回特性(FLASHBACK DROP & RECYCLEBIN)

转载自:https://blog.csdn.net/leshami/article/details/6105327 FLASHBACK DROP 特性允许在不丢失任何数据库的情况下将指定的表恢复至其被删除的时间点,并保持数据库为当前状态.闪回删除并不是真正的删除表,而是把该表重命名并放入回收站,类似于Windows的回收站一样.当某个活动对象需要使用该表所占用的空间时,该表才会被真正删除.只要空间未被复用,该表即可恢复.本文主要讲述了FLASHBACK DROP特性以及闪回特性中回收站(RECY

4. Oracle 闪回特性(Flashback Version、Flashback Transaction)

转载自:https://blog.csdn.net/leshami/article/details/6112981 Oracle闪回特性为数据的快速回复某一对象的特定数据提供了更多的便利.前面介绍了闪回的几种特性,包括flashback database,flashback drop ,flashback query ,flashback table .接下来本文将介绍Flashback Version与Flashback Transaction. 一.Flashback Version Que

Oracle闪回查询恢复delete删除数据

Flashback query(闪回查询)原理 Oracle根据undo信息,利用undo数据,类似一致性读取方法,可以把表置于一个删除前的时间点(或SCN),从而将数据找回. Flashback query(闪回查询)前提: SQL> show parameter undo; NAME                                TYPE       VALUE ------------------------------------ ----------- --------

专题实验 oracle 闪回特性

在 oracle 9i 之前的版本中, 如果用户因为误操作 delete 或 update 并提交了, 那么恢复这些用户的操作错误是极其低效的. 为此, oracle 提供了闪回功能, 通过回退, 我们可以找回正确的数据. oracle 闪回查询特性 通过闪回查询我们可以按照时间戳或SCN来向前查询, 获取修改之前的数据镜像, 再通过insert等操作就可以恢复数据. 闪回查询一来于回滚段中存储的数据前镜像, 在oracle9i以前的版本中, 通常只要事务提交后, 前镜像数据就可以被覆盖, 空间

Oracle 闪回

Oracle闪回技术 1.Flashback Database 2.Flashback Drop 3.Flashback Table 4.Flashback Query 1.Flashback Database(利用闪回日志恢复) 描述:Oracle Flashback Database特性允许通过SQL语句Flashback Database语句,让数据库前滚到当前的前一个时间点或者SCN.闪回数据库可以迅速将数据库回到误操作或人为错误的前一个时间点,如ctrl+Z操作,可以不利用备份就快速的

oracle闪回表详解

--- 说明闪回数据库 --- 使用闪回表将表内容还原到过去的特定时间点 --- 从删除表中进行恢复 --- 使用闪回查询查看截止到任一时间点的数据库内容 --- 使用闪回版本查询查看某一行在一段时间内的各个版本 --- 使用闪回事务查询查看事务处理历史记录或行 会还原表及其关联对象(如索引.约束条件.触发器等)中的数据. 所谓闪回表,就是将表里的数据回退到历史的某个时间点,比如回退到用户误删除数据之前的时间点,从而将误删除的数据恢复回来,在这个操作过程中,数据库仍然可用而且不需要额外的空间.

Oracle闪回

Oracle闪回作用:自动基于磁盘的备份与恢复,能把表恢复到过去的某个时间点或者SCN. 1.查看闪回区 SQL> show parameter db_recovery_file_dest;  查看闪回区详细信息 SQL> select flashback_on from v$database;  查看闪回区是否开启 2.修改闪回功能 SQL> startup mount;               数据库启动到mount下 SQL> alterdatabase flashbac

oracle闪回查询和闪回数据库

oracle闪回查询和闪回数据库 区别: 数据闪回查询,只需要启用撤销表空间自动管理回滚信息. 使用闪回删除技术和闪回数据库技术,需要启动回收站,闪回恢复区.(归档模式使用) 具体设置: ---cmd sqlplus nolog sys as sysdba hanatech 具体设置----数据闪回查询的设置: 查看撤销表信息undo: show parameter undo; 设置撤销表信息: alter system set undo_managerment=auto;设置为auto才可以使