提交DML操作后,该操作使用的还原段就可以被其它对象使用了,为了保证闪回操作时这些数据仍然被保存在还原段中,可能需要重新设置undo_retention参数,表示一个事务提交后,该事务的数据必须保存在还原段中的时间;但是这也并不能完全保证指定的时间的数据一定能够被恢复,还原表空间没有足够的时间时,仍会覆盖要求保留的磁盘空间。

查看undo_retention的当前值:

SQL> show parameter undo_retention

NAME                     TYPE     VALUE
------------------------------------ ----------- ------------------------------
undo_retention integer 900

默认是900s

设置undo_retention的值为2个小时

SQL> alter system set undo_retention = 7200;

系统已更改。

实例测试1,根据SCN号闪回:

  目标:将emp_bak表中的员工的工资统一更新为9999,提交后使用闪回技术回滚回初始值。

--更新emp_bak

SQL> update emp_bak set sal = 9999;

已更新10行。
SQL> commit; 提交完成。

--查出更新操作对应的事务号

SQL> select  versions_xid,ename,sal from emp_bak
versions between scn minvalue and maxvalue
where empno = 7900; VERSIONS_XID ENAME SAL
---------------- ---------- ---------
08001D0018060000 JAMES 9999.00
JAMES 950.00

  versions_xid为事务号,minvalue为最小值,maxvalue为最大值。

--从数据字典flashback_transaction_query中查询出事务号所对应的SCN号

select start_scn from flashback_transaction_query
2 where xid = hextoraw('08001D0018060000'); START_SCN
----------
2206522
2206522
2206522
2206522
2206522
2206522
2206522
2206522 已选择8行。

--启用行移动功能, 否则不能闪回表

SQL> alter table scott.emp_bak enable row movement;

表已更改。

--闪回表

SQL> flashback table scott.emp_bak to scn 2206522;

闪回完成。

SQL> select sal from scott.emp_bak where empno=7900;

       SAL
----------
950

闪回已经完成了。

 注意闪回是闪回到该SCN之前的一个状态。

如果查询flashback_transaction_query视图中的列operation全是unknown 而且undo_sql 也为空,要开启对DML更改引用的列值和主键值的日志记录

SQL>  alter database add supplemental log data (primary key) columns;

再查询就可以见到了

SQL> select  start_scn,operation,undo_sql from flashback_transaction_query
2 where xid = hextoraw('05000C00DE060000'); START_SCN OPERATION UNDO_SQL
---------- -------------------------------- --------------------------------------------------------------------------------
2210297 UPDATE update "SCOTT"."EMP_BAK" set "JOB" = NULL where ROWID = 'AAASNGAAEAAAADrAAT';
2210297 UPDATE update "SCOTT"."EMP_BAK" set "JOB" = NULL where ROWID = 'AAASNGAAEAAAADrAAS';
2210297 UPDATE update "SCOTT"."EMP_BAK" set "JOB" = NULL where ROWID = 'AAASNGAAEAAAADrAAR';
2210297 UPDATE update "SCOTT"."EMP_BAK" set "JOB" = NULL where ROWID = 'AAASNGAAEAAAADrAAQ';
2210297 UPDATE update "SCOTT"."EMP_BAK" set "JOB" = NULL where ROWID = 'AAASNGAAEAAAADrAAP';
2210297 UPDATE update "SCOTT"."EMP_BAK" set "JOB" = NULL where ROWID = 'AAASNGAAEAAAADrAAO';
2210297 UPDATE update "SCOTT"."EMP_BAK" set "JOB" = NULL where ROWID = 'AAASNGAAEAAAADrAAN';
2210297 UPDATE update "SCOTT"."EMP_BAK" set "JOB" = NULL where ROWID = 'AAASNGAAEAAAADrAAM';
2210297 UPDATE update "SCOTT"."EMP_BAK" set "JOB" = NULL where ROWID = 'AAASNGAAEAAAADrAAL';
2210297 UPDATE update "SCOTT"."EMP_BAK" set "JOB" = NULL where ROWID = 'AAASNGAAEAAAADrAAK';

实例测试2,根据时间闪回:

1. 利用Flashback Table特性
需要开启行移动
alter table test enable row movement;
flashback table test to timestamp to_timestamp('20171018234845','yyyymmddHH24miss');

2. 利用Flasback Query特性,这种方法最通用且实用
不需要开启行移动,直接查询出不同时间的数据,并保存在临时表中
create table test_tmp as select * from test as of timestamp to_timestamp('20171018234845','yyyymmddHH24miss');

Oracle的闪回技术--闪回错误的DML操作的更多相关文章

  1. Oracle的闪回技术--闪回已删除的表

    注意闪回技术只能保护非系统表决空间中的表,而且表空间必须本地管理, 外键将不可以被恢复, 索引和约束的名字将会被命名为以BIN开头,由系统生成的名字 查看是否开启闪回: SQL> show pa ...

  2. php中对MYSQL操作之预处理技术(1)数据库dml操作语句

    <?php //预处理技术 //创建一个mysqli对象 $mysqli = new MySQLi("主机名","mysqlusername"." ...

  3. oracle中闪回错误的dml操作原理

    原理: Oracle根据还原表空间信息,利用还原表空间中的数据,类似一致性读取方法,可以把表置于一个删除前的时间点(或SCN),从而将数据找回. 删除删除错误的dml操作的oracle的前提准备: 一 ...

  4. Oracle闪回技术详解

     概述: 闪回技术是Oracle强大数据库备份恢复机制的一部分,在数据库发生逻辑错误的时候,闪回技术能提供快速且最小损失的恢复(多数闪回功能都能在数据库联机状态下完成).需要注意的是,闪回技术旨在快速 ...

  5. Oracle闪回技术(Flashback)

    闪回技术有闪回表.闪回删除.闪回查询.闪回事务查询.闪回事务.闪回数据库.闪回数据归档.其中,闪回查询.闪回事务查询用来“观察”过去:闪回数据归档并不是一个独立的功能,其功能是扩展闪回查询的时间窗口: ...

  6. Oracle 六闪回技术,flashback

    Flashback 技术基于Undo segment基于内容的, 因此,限制UNDO_RETENTON参数. 要使用flashback 特征,您必须启用自己主动撤销管理表空间. 在Oracle 11g ...

  7. Oracle Flashback Technology【闪回技术】

    -------------------------与其他数据库相比,Oracle的闪回让开发者多了一条选择的路. Flashback的目的 先看下Oracle官方文档中的解释: Oracle Flas ...

  8. Oracle闪回技术

    (一)闪回技术概要 闪回技术是数据库备份与恢复的重要补充手段,主要包括以下7种特性: 特性 原理 数据库支持 闪回查询(Flashback Query) 利用undo表空间中的回退信息,查询过去某个时 ...

  9. Oracle 的闪回技术 --flashback

    SQL Fundamentals: 表的创建和管理 如何开启数据库闪回? SQL> shutdown immediate; ORA-01109: database not open Databa ...

随机推荐

  1. 企业架构与建模之使用ArchiMate进行分析

    企业架构与建模之使用ArchiMate进行分析(全系列完) 4. 使用ArchiMate进行分析 正如前面所说的那样,一个企业整体效率的提升有时并不是通过某一个领域内的优化就能达到的,而且这种忽视全局 ...

  2. 【转载】Stack Overflow: The Architecture - 2016 Edition

    转载:http://www.infoq.com/cn/news/2016/03/Stack-Overflow-architecture-insi?utm_source=tuicool&utm_ ...

  3. Cocos2d学习之路五(Box2d使用CCPhysicsSprite时编译不通过解决方法)

    cocos2d使用box2d引擎,在使用CCPhysicsSprite添加精灵的时候会出现编译不通过错误. 需要注意以下几点: 1.sprite.position=ccp(p.x,p.y);这行代码一 ...

  4. C#中鼠标划过按钮时候的提示信息

    ToolTip p = new ToolTip();            p.ShowAlways = true;            p.SetToolTip(this.Buton1, &quo ...

  5. 鸟哥的LINUX私房菜基础篇第三版 阅读笔记 四 档案的文件系统的压缩和打包

    1.压缩文件案的用途与技术     a.用途,简单来说,就是节约磁盘空间.如果从传输角度讲,占用宽带也会小很多(Apache就有自动压缩的功能,节省宽带资源,提升网站的输出能力)     b.压缩技术 ...

  6. QSQL导出mapfile和mapfile中PostGIS连接的一点心得

    昨天弄QSQL导出mapfile,一直遇到下图的错误 原因是QGIS在渲染图层时候使用了新的符号,在图层上右键-属性,如下图将符号修改就OK了 然后我尝试使用QGIS连接本机PostGIS数据,结果老 ...

  7. jquery ready方法实现原理 内部原理

    jquery ready方法实现原理 内部原理 今天闲来无事研究研究jquery.ready()的内部实现,看JQ的源码一头雾水,由于自己很菜了,于是翻了翻牛人的播客,讲述详细,收获颇多. 先普及一下 ...

  8. Yellow

    Yellow这首歌让我知道了yellow这个单词出了黄色的意思外,还有胆怯的,懦弱的意思~~~ 它是Coldplay 的歌曲,歌词很简单,但是有着莫名的忧伤感,值得一提的是这首歌的MV,一个长镜头给出 ...

  9. Python学习入门基础教程(learning Python)--6.4 Python的list与函数

    list是python下的一种数据类型,他和其他类型如整形.浮点型.字符串等数据类型一样也可作为函数的型参和实参来使用! 1.list作为参数 list数据类型可以作为函数的参数传递给函数取做相应的处 ...

  10. 最近学习了下BI(商业智能)做报表

    最近公司购买了Style intelligence 出的BI报表工具,接触新的东西不是很容易上手,这个东西是别的项目组用的,我们项目组由于进度比较快就让我先到他们项目组帮他们,为了使用这个东西,他们已 ...