Oracle的闪回技术--闪回错误的DML操作
提交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操作的更多相关文章
- Oracle的闪回技术--闪回已删除的表
注意闪回技术只能保护非系统表决空间中的表,而且表空间必须本地管理, 外键将不可以被恢复, 索引和约束的名字将会被命名为以BIN开头,由系统生成的名字 查看是否开启闪回: SQL> show pa ...
- php中对MYSQL操作之预处理技术(1)数据库dml操作语句
<?php //预处理技术 //创建一个mysqli对象 $mysqli = new MySQLi("主机名","mysqlusername"." ...
- oracle中闪回错误的dml操作原理
原理: Oracle根据还原表空间信息,利用还原表空间中的数据,类似一致性读取方法,可以把表置于一个删除前的时间点(或SCN),从而将数据找回. 删除删除错误的dml操作的oracle的前提准备: 一 ...
- Oracle闪回技术详解
概述: 闪回技术是Oracle强大数据库备份恢复机制的一部分,在数据库发生逻辑错误的时候,闪回技术能提供快速且最小损失的恢复(多数闪回功能都能在数据库联机状态下完成).需要注意的是,闪回技术旨在快速 ...
- Oracle闪回技术(Flashback)
闪回技术有闪回表.闪回删除.闪回查询.闪回事务查询.闪回事务.闪回数据库.闪回数据归档.其中,闪回查询.闪回事务查询用来“观察”过去:闪回数据归档并不是一个独立的功能,其功能是扩展闪回查询的时间窗口: ...
- Oracle 六闪回技术,flashback
Flashback 技术基于Undo segment基于内容的, 因此,限制UNDO_RETENTON参数. 要使用flashback 特征,您必须启用自己主动撤销管理表空间. 在Oracle 11g ...
- Oracle Flashback Technology【闪回技术】
-------------------------与其他数据库相比,Oracle的闪回让开发者多了一条选择的路. Flashback的目的 先看下Oracle官方文档中的解释: Oracle Flas ...
- Oracle闪回技术
(一)闪回技术概要 闪回技术是数据库备份与恢复的重要补充手段,主要包括以下7种特性: 特性 原理 数据库支持 闪回查询(Flashback Query) 利用undo表空间中的回退信息,查询过去某个时 ...
- Oracle 的闪回技术 --flashback
SQL Fundamentals: 表的创建和管理 如何开启数据库闪回? SQL> shutdown immediate; ORA-01109: database not open Databa ...
随机推荐
- sendrose【SPFA】
之前看到一题需要并查集+SPFA,然后就特别囧的发现自己SPFA这个历史遗留问题已经不知道怎么打了╮(╯▽╰)╭ 就果断挑了一题特别裸的SPFA赶紧搞搞掉,顺便自己乱YY下学SPFA的笔记,免得自己下 ...
- [转]Apple iPod, iPhone (2g, 3g), iPad Dock connector pinout
Pin Signal Description Apple pin numbering* 1 GND Ground (-), internally connected with Pin 2 on iPo ...
- 在 Emacs 中如何退出 Slime Mode
1.在 Slime 的 Buffer 中按逗号“,”: 2.在 Command 后输入:sayoonara 3.回车,确认. ================ 退出 SBCL 输入:(sb-ext:q ...
- 哞哞快的 C# 高斯模糊实现
冲动来自于 bing best 这个小工具,非常短小精干,里边的设置界面非常精美而且背景是一张模糊效果的图片,十分养眼,遂想,收集一下实现方式放到类库里以后肯定用得上.一通百度.谷歌.博客园,换了好多 ...
- iOS 动画类型 笔记
#pragma mark Core Animation - (IBAction)buttonPressed1:(id)sender { UIButton *button = (UIButton *)s ...
- hdu 4277 USACO ORZ (dfs暴搜+hash)
题目大意:有N个木棒,相互组合拼接,能组成多少种不同的三角形. 思路:假设c>=b>=a 然后枚举C,在C的dfs里嵌套枚举B的DFS. #include <iostream> ...
- 分享一套 CodeSmit 代码生成模板。
分享一套 CodeSmit 代码生成模板. 住博客园 5 年了,以前也发过一些博文,但都在 一天后 / 几周后 / 几年后 将它删了:因为感觉代码写得不好:不清晰或侵入太大,哪怕只有一句侵入. 可是最 ...
- POJ 3342 - Party at Hali-Bula 树型DP+最优解唯一性判断
好久没写树型dp了...以前都是先找到叶子节点.用队列维护来做的...这次学着vector动态数组+DFS回朔的方法..感觉思路更加的清晰... 关于题目的第一问...能邀请到的最多人数..so ea ...
- 用JSP+JavaBean开发模式实现一个销售额的查询
数据库使用mysql,如下: vo包的Sales类: package com.vo; public class Sales { public String salestime; public fl ...
- 《DSP using MATLAB》示例Example6.4
图形表达如下: 代码: b = [1, 0, 0, 0, 16+1/16, 0, 0, 0, 1]; [b0, B, A] = dir2cas(b, 1) 运行结果: 写成公式为