涂抹Oracle—Flashback
11.1 基于flashback查询过去的数据
a.基于时间的查询(as of timestamp)
构造表falsh_tbl,删除数据然后查询
SQL>select * from flash_tbl as of timestamp sysdate-5/1440;
恢复删除的数据
SQL>insert into flash_tbl select * from flash_tbl as of timestamp sysdate-5/1440 where id<10;
实验的时候,注意删除之后过去的时间,不然在恢复的时候会报表结构变更的错误提示。
b.基于SCN的查询(AS OF SCN)
获取SCN的方法:
a.select current_scn from v$database;
b.select dbms_flashback.get_system_change_number from dual;
b的前提是要有操作对象的访问权限:
>grant execute on dbms_flashback to user;
获取SCN,然后删除操作并提交:
>select dbms_flashback.get_system_change_number from dual;
>delete flash_tbl where id>10;
执行select语句并附加as of scn,同时指定删除前的SCN,可以查询到指定SCN时对象中的记录:
>select * from flash_tbl as of scn .....;
执行insert,将删除的数据重新恢复回表:
SQL>insert into flash_tbl select * from flash_tbl as of scn .... where id>10;
SQL>commit;
使用scn查询比timestamp更精确
不过在实际执行flashback query时,时间转换后具体对应哪个SCN,通过sys用户下smon_scn_time来记录
SQL>desc sys.smon_scn_time;
在10g中,系统评价每3秒产生一次系统时间与SCN的匹配并存入sys.smon_scn_time表:
>select scn,to_char(time_dp,'YYYY-MM-DD HH24:MI:SS') as time from sys.smon_scn_time order by time;
在oracle数据库也可手动进行时间和SCN的转换,oracle提供了两个函数SCN_TO_TIMESTAMP和TIMESTAMP_TO_SCN
SQL> SELECT TIMESTAMP_TO_SCN(SYSDATE) FROM DUAL;
SQL> SELECT TO_CHAR(SCN_TO_TIMESTAMP(4942206),'YYYY-MM-DD HH24:MI:SS') FROM DUAL;
11.1.2 应用flashback Query查询操作的事务
11.1.2.1 使用flashback version query查询记录修改版本
查询过去某个时间点对象中保存的记录信息,在当前时间与指定的过去某个时间点之间,对象可能做过多次修改。
flashback version query也是以select查询后面附加versions between timestamp[/SCN] start and end子句即可。通过version between能够查看指定时间段内undo表空间记录的不同版本.
11.1.2.2 使用flashback transaction query查询事务信息
flashback transaction query功能在实际应用时对应的是个视图:flashback_transaction_query
注意:查询flashback_transaction_query视图,用户需要是DBA角色,或被授予了select any transaction权限
>grant select any transaction to xxx;
11.1.3 应用flashback query注意事项
11.1.3.1 自动撤销管理表空间
要使用flashback的相关特性,必须启用自动撤销管理表空间,不单单对于flashback query,也包括flashback table和flashback database,对于后两项还有其它附件条件,如flashback table需要启用recycle bin(回收站),flashback database 要求启用flashback area(闪回区)
9i后取消回滚段说法,完全以UNDO段代替,正好与REDO概念相对应.
UNDO端不再由DBA手工介入,完全由oracle在运行时自动分配.
是否启用自动撤销管理表空间由两个初始化参数决定:
.undo_management:值为auto表示使用自动撤销表空间管理,manual则表示手动
.undo_tablespace:oracle数据库中个可以创建多个undo表空间,不过同时只能使用一个,当undo_management初始化参数为auto时,undo_tablespace参数用来指定当前使用的undo表空间名称
undo表空间大小,直接影响到flashback query的查询能力。
11.1.3.2 初始化参数undo_retention
用来指定undo段中数据保存的最短时间,以秒为单位,是一个动态参数,可以在实例运行随时修改,默认900秒,15min
11.2 Flashback Table闪回表
oracle10g引入一个recycle bin的功能(主要针对被删除的表及其关联的对象,如触发器、索引、约束),被删除的表并非真正删除,而是先通过修改数据字典的方式,将其改名并放入recycle bin中,如果要恢复recycle bin中的对象,借助flashback table是最简便的方式
11.2.1.1 删除恢复实验
SQL>drop table temp1;
SQL>select object_name,original_name from recyclebin;
如果commit恢复没有用
SQL>flashback table temp1 to before drop;
涂抹Oracle—Flashback的更多相关文章
- Oracle Flashback Technology【闪回技术】
-------------------------与其他数据库相比,Oracle的闪回让开发者多了一条选择的路. Flashback的目的 先看下Oracle官方文档中的解释: Oracle Flas ...
- Oracle Flashback Technologies - 闪回查询
Oracle Flashback Technologies - 闪回查询 查看表中,某行数据的修改记录 #创建一个表,并插入和修改数据 SQL> create table y3(id )); T ...
- Oracle Flashback Technologies - 闪回被drop的表
Oracle Flashback Technologies - 闪回被drop的表 在oracle10g中,drop一个表后,表没有真正被删除,支持被rename后放在recyclebin中. #新建 ...
- Oracle Flashback Technologies - 估算不同时间段闪回日志的产生量
Oracle Flashback Technologies - 估算不同时间段闪回日志的产生量 v$flashback_database_stat监控闪回数据的i/o开销的统计信息,根据之前的系统负载 ...
- Oracle Flashback Technologies - 闪回数据库
Oracle Flashback Technologies - 闪回数据库 根据指定的SCN,使用rman闪回数据库 #查看可以闪回到多久前 SQL> select * from v$flash ...
- Oracle Flashback Technologies (总)
Oracle Flashback Technologies Oracle 9i中增加了闪回查询技术,闪回查询为数据库提供了一种简单.强大.完全无干扰从人为错误中恢复的机制.通过闪回查询,用户可以查看过 ...
- oracle flashback
一.Flashback闪回技术概述:当Oracle数据库发生逻辑错误时,必须使用flashback技术,实现快速和方便的恢复数据.对于人为错误,要确定受到错误事务影响的对象或者记录是非常困难的.使用f ...
- ORACLE FLASHBACK DATABASE 知识整理
1.知识储备 1) 只有SYSDBA有权执行,闪回前一定要记录当前SCN 2) 需要停机,并要求处于ARCHIVELOG模式中 3) 闪回日志不能被复用和归档,是自动管理的.RVWR ...
- Oracle Flashback 详解
Oracle flashback 是一种方便快捷的数据库恢复技术,它不使用备份文件,通过闪回日志可以使数据库恢复到过去的某个状态,当用户发生逻辑错误时(误删表数据.表.表空间等)需要快速恢复数据库,可 ...
随机推荐
- python模块管理
参考python的模块管理,请看如下 http://blog.sina.com.cn/s/blog_90bc5fc6010159e0.html http://hi.baidu.com/billsche ...
- Post/Redirect/Get pattern | PRG 模式
Post/Redirect/Get 是一种 web 开发设计模式,用于防止表单的重复提交. 默认情况,提交 Post 请求到服务器后,如果直接刷新浏览器,会重新在提交一次 Post 请求.在访问电商网 ...
- sqlserver查看索引使用情况以及建立丢失的索引
--查看表的索引使用情况SELECT TOP 1000o.name AS 表名, i.name AS 索引名, i.index_id AS 索引id, dm_ius.user_seeks AS 搜索次 ...
- 有趣的js符号{}、[]、""、~、++等转换
(!(~+[])+{})[--[~+""][+[]]*[~+[]] + ~~!+[]]+({}+[])[[~!+[]]*~+[]] http://www.jointforce.co ...
- js转码和解码兼容低版本火狐
function HTMLEncode(html) { var temp = document.createElement("div"); ...
- python常用的一些东西——sys、os等
1.常用内置函数:(不用import就可以直接使用) help(obj) 在线帮助, obj可是任何类型 callable(obj) 查看一个obj是不是可以像函数一样调用 ...
- NDK GDB 中打印vector , vector<vector <> >
在android上进行native开发的时候,我们需要用NDK-GDB 对native code进行调试,其中很麻烦的是,我使用的NDK版本是4.0,该版本还不支持用NDK-GDB直接打印vector ...
- asp.net微信开发第七篇----高级群发(图文)
上一篇介绍了如何群发文本消息,本篇将介绍如何群发图文信息,上传图文信息所需的素材,界面如下: 我们先看从素材库中获取图文素材的代码,界面: 素材列表,我是使用的repeater控件, 前台代码如下: ...
- (转)Discuz!NT图文安装教程
不同目录下的安装方法根据目前大家对论坛的使用需求,在安装上面大致有三种情况,站点根目录下安装,站点虚拟目录下安装和站点子目录下安装. 1.根目录安装 根目录安装是最简单也是稳定系数最高的安装和使用方式 ...
- JAVA为什么会空指针异常
1.所谓的指针,就是java中的对象的引用.比如String s;这个s就是指针. 2.所谓的空指针,就是指针的内容为空,比如上面的s,如果令它指向null,就是空指针. 3.所谓的空指针异常,就是一 ...