最简单的Oracle数据恢复 select as of使用方法


You perform a Flashback Query by using a SELECT statementwith an AS OF clause.You use a flashback query to restrieve data as it existed at some time in the past.The query explicitly references a past time by menasof timestamp or SCN.It returns committed data that was current at that point intime.
通过执行一个带as of 子句的select语句进行闪回查询,可以闪回检索过去某个时间存在的数据,一个闪回查询被用来重现过去存在过的数据,这个查询明确的引用了过去的一个时间段或SCN号,闪回查询返回的数据都是过去某时刻已经提交的数据。

Potential uses of Flashback Query include:
可能使用到闪回查询的地方:
⊙Recovering lost data or undoing incorrect,committed changes.For example,if you mistakenly delete or update rows,and then commit them,you can immediately undo the mistake.
恢复丢失的数据或撤销已经提交的错误。例如如果你不小心删除或更新了行,并且做了提交操作,你可以立刻撤销这个错误。
⊙Comparing current data with the corresponding data at some time in the past.For example,you might run a daily report that shows the change in data from yesterday.You can compare the individual rows of table data or find intersections or unions of sets of rows.
比较当前数据和历史数据的一致性。例如,你可能需要生成一份前一天数据更新的日报告,你可以分别比较表的每一行或找到行的交集和并集。
⊙Checking the state of transactional data at a particular time.For example,you could verify the account balance of a certain day.
在某个特殊时间检查事务型数据的状态。例如,你可以在某一天验证账户收支。
⊙Simplifying the application design,by removing the need to store some kinds of temporal data.By using a Flashback Query, you can retrieve past data directly from the database.
移除某些因需求储存的暂时数据以简化应用设计。通过闪回查询你可以从数据库中直接获取到过去的数据。
⊙Applying the packaged applications such as report generation tools to past data.
使用包装应用(例如报表生成工具)的历史数据
⊙Providing self-service error correction for anapplication,thereby enabling users to undo and correct their errors.
为应用提供自服务错误更正,因此可以让用户撤销或更正他们的错误。
 
示例:
 
SQL> conn /as sysdba;
已连接。
SQL> set pagesize 200
SQL> select * from scott.dept;
 
    DEPTNO DNAME                        LOC
---------- ---------------------------- -------------------------
        10 ACCOUNTING                   NEW YORK
        20 RESEARCH                     DALLAS
        30 SALES                         CHICAGO
        40 OPERATIONS                   BOSTON
现在,我们来增加一条数据,并提交:
 
SQL> insert into scott.dept values(50,'错误数据','CHINA');
已创建 1 行。
 
SQL> select * from scott.dept;


    DEPTNO DNAME                        LOC
---------- ---------------------------- -------------------------
        10 ACCOUNTING               NEW YORK
        20 RESEARCH                 DALLAS
        30 SALES                         CHICAGO
        40 OPERATIONS               BOSTON
        50 错误数据                     CHINA
 
SQL> commit;(2011-12-9 10:51:00)


提交完成。
正常情况下,由于已经做了commit操作,所以rollback已经无效了,要想得到2011-12-9 10:51:00之前的数据,怎么办?
使用timestamp时间点闪回:
SQL> select * from scott.dept as of timestamp to_timestamp('2011-12-09 10:00:00','yyyy-mm-dd hh24:mi:ss');
 
    DEPTNO DNAME                        LOC
---------- ---------------------------- -------------------------
        10  ACCOUNTING                   NEW YORK
        20  RESEARCH                      DALLAS
        30  SALES                         CHICAGO
        40  OPERATIONS                   BOSTON
闪回查询,主要依靠表空间的undo数据,如果想要追溯更久的数据,就需要设置较大的undo_tablespaces大小和undo_retention。
 
如果想直接更新当前的表到历史的某个时间状态,可以直接使用flashback关键字:
 
 
SQL> alter table scott.dept enable row movement;


表已更改。
 
SQL> flashback table scott.dept to timestamp to_timestamp('2011-12-09 10:00:00','yyyy-mm-dd hh24:mi:ss');


闪回完成。
 
【注意】:
闪回不是万能的,当一个表的数据较大或时间过长时,如果没有设置较大的闪回空间和时间,闪回操作将会失败,可能会出现以下错误:



相关阅读:
苹果Mac查看硬盘是否开启ACHI模式的方法图解
php实现数组筛选奇数和偶数示例
谈一谈js中的执行环境及作用域
使用getBoundingClientRect方法实现简洁的sticky组件的方法
asp.net 图标提取以及图标转换的实例代码
Android App开发中Gradle构建过程的配置方法
jQuery中阻止冒泡事件的方法介绍
HTML5几个设计和修改的页面范例分享
.NET运行界面上,实现随意拖动控件的方法
用PHP提取中英文词语以及数字的首字母的方法介绍
Win7复制文件时提示错误代码0X80070057的解决方法
javascript实现动态加载CSS
js实现的黑背景灰色二级导航菜单效果代码
PHP页面中文乱码分析
快速导航
PHP MySQL HTML CSS JavaScript MSSQL AJAX .NET JSP Linux Mac ASP 服务器 SQL jQuery C# C++ java Android IOS oracle MongoDB SQLite wamp 交通频道 作文范文 我在变作文400字 2016国庆印象 竹作文250字 我快乐,因为我诚实 应用电子专业大学生求职信范文 【闲钓兰溪湖】 呼唤作文400字 霓虹灯下的寂寞... 当自己被人喜欢的时候呀,感觉身上都在放光(爱情语录) 我们身边的年例 防盗变形房 公务员入党申请书样本 小学五年级作文550字:车厢里的温暖 六年级作文800字:爱踢足球的我 论金钱作文900字 2015年关于岗前培训心得体会 爱我侦探团—古铜城堡连环绑架案作文350字 小记者,我的梦作文800字 俄要的就只是简简单单而已 毕业晚会开场白结束语 一心为人民甘愿做“傻子”550字 在学校的你一定遇到过这么些情况作文1400字 最美的雪景 北师大版必修一三单元--必修(一)第三单元测试(原创)(会员上传) 夏曰(yue)(贰) 父母对我的教育 高中高三作文1000字:西西旅游记 经典人生青春励志大全 小学三年级作文300字:天塔——-家乡的明珠 加班族 水仙花500字 《农业的区位选择》导学案 红牛公司甘做“冤大头” 高尚造句 全新手把手作文 抵不过 何日出头? 别再视而不见了,感情,不是失去后才去拿来珍惜的 清澈在景,清净在心 八一建军,送我亲爱的军人诗歌 战场依旧,物是人非 禅意的秋 小学四年级作文500字:参观我们的校园 星辰寥落,月如玦 精选入党申请谈话内容(简洁版) 小学五年级作文550字:提醒幸福 在思想世界外的温暖 我的小伙伴 晏子 节约用水从我做起作文900字 80后,沦为不折不扣加班狂的无奈。。。

Copyright © 2016 phpStudy |