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 ...
随机推荐
- 2013集训.DAY21.A
随便点了一套刷,这套质量挺棒的,学了不少的东西,并且碰到了很久都没有打的题目 T1 card [指针技巧] 题1 集卡片 [问题描述] lzh小时候很喜欢收集卡片,他经常要去商店购买新到的卡片. 商店 ...
- MongoDB:锁机制
--1 MongoDB 使用的锁 MongoDB 使用的是“readers-writer”锁, 可以支持并发但有很大的局限性,当一个读锁存在,许多读操作可以使用这把锁,然而, 当一个写锁的存在,一个单 ...
- 使用VS2010命令提示窗口操作程序集强命名
说明:文中示例均以将文件置于D盘根目录(D:\)下为例. 一.查看程序集是否具有强命名 sn -T d:\LicBase.dll 若有则会显示PublicKeyToken值,反之不会. 二.给无强命名 ...
- linux 之 snprintf函数用法
int snprintf(char *restrict buf, size_t n, const char * restrict format, ...); 函数说明:最多从源串中拷贝n-1个字符到 ...
- 为什么选择MongoDB?
为什么选择MongoDB? 阅读目录 开始 为啥用MongoDB? 原来的架构 新需求 如何解决? 新思路 选型条件 一些候选者 最初的选择 代价 新的候选者 重新选择 胆子大一点 胆子再大一点 胆子 ...
- No object in the CompoundRoot has a publicly accessible property named
No object in the CompoundRoot has a publicly accessible property named 'typeid' (no setter could be ...
- 里氏替换原则LSP(继承规范)
继承的优点: 1.代码共享,减少创建类的工作量,每个子类都拥有父类的方法和属性. 2.提高代码的重用性. 3.子类可以形似父类,但又异于父类. 4.提高代码的可扩展性,实现父类的方法就可以“为所欲为” ...
- C# ToString格式控制符
C 货币 2.5.ToString("C") ¥2.50 D 十进制数 25.ToString("D5") 00025 E 科学型 25000.ToString ...
- 2440开发板linux系统移植3G拨号上网收发短信(三)
一.用text查看模式 下面的“发”是指我敲的命令,“收”是指回车后显示的信息包括其他接收的信息. ~ >: microcom -s 115200 /dev/ttyUSB1 发:at 收:OK ...
- 人生在于折腾:php实现下载导出xx.tar.gz
刚接到这样的需求,其实我是拒绝的.我甚至很有耐心地和pm商量,扔个csv不就好了么? pm:对方需要一个csv打包成.tar.gz的包,他们是linux server,这是硬性要求. 然后我开始折腾之 ...