有时候我们在操作ORACLE数据库的时候,可能由于SQL写错了导致把数据update错了,或者delete删除掉了,那么这时候如何去恢复之前的数据呢?
莫着急,我们可以采用oracle的基于时间查询as of timestamp的办法进行恢复数据。下面以具体例子进行讲解用法。
1、比如,我的wl_notify_task表目前有三条数据,大家重点关注PARAMETER字段。
2、我现在做一个update操作,要把id=1的parameter字段更新为param_test8,但是由于我操作的失误,id=1条件忘了加了,导致整表更新了。导致其他记录的parameter字段全部都是param_test8
update wl_notify_task set parameter = ‘param_test8′
杯具发生了,那么如何再找到我之前的记录是什么呢??
3、没事,我们可以采用oracle的基于时间查询的办法查询出3分钟前的表的记录情况,查询SQL如下:
SELECT * FROM wl_notify_task AS OF TIMESTAMP SYSDATE – 3/1440
对SQL的解释说明:
SYSDATE :当前时间
1440 :24h*60m=1440m
3:3分钟前
4、通过上面的查询,我们看到了在update之前的数据情况。那么把数据恢复回去就很简单了,通过ID关联的方式更新回去即可。如下:
update wl_notify_task t1
set t1.parameter =
(select parameter
from wl_notify_task AS OF TIMESTAMP SYSDATE – 3 / 1440
where t1.id = id)
这种做法也是DBA常用的恢复数据的手段。对于删除的情况,那么就通过insert办法重新把记录插入表即可。
最后需要特别提醒大家注意的是,SQL中的 SYSDATE-3/1440 代表查询3分钟前的记录情况,由于是和当前时间SYSDATE的距离3分钟前,所以这个随着隔的时间不同及时间的推移是会变化的,一般的做法是在真正做恢复时的update前,需要先select查询一下比如3分钟前的数据是否是我们想要的数据,确认无误后立即做恢复的update。如果数据不是我们想要的,那么就需要通过调节分钟数直到找到我们想要的数据。这种办法适合小批量数据,如果是大批量数据且很重要的数据的话,建议大家新建一张结构相同的表,先把as of timestamp查询出来的数据存到新表中,再进行恢复操作,因为这样数据不再受时间差的影响,确保数据是准确的,无论你何时开始做恢复操作。
转自:http://wangchongan.com/articles/oracle-data-update-delete-recover.html
相关推荐
Oracle恢复误删除数据 Oracle恢复误删除数据 Oracle恢复误删除数据
Oracle恢复误删除数据,解除锁定的等SQL语句
SCN提供了Oracle的内部时钟机制,可被看作逻辑时钟,这对于恢复操作是至关重要的 注释:Oracle 仅根据 SCN 执行恢复。 它定义了数据库在某个确切时刻提交的版本。在事物提交时,它被赋予一个唯一的标示事物的SCN ...
Oracle必杀技物理删除数据文件恢复,详解了实用的Oracle物理表空间删除修复命令。
有时候我们不小心把数据删掉,或者数据莫名其妙的丢失,这时候我们可以借助Oracle本身自带的快照来进行数据的恢复。
NULL 博文链接:https://steve-111.iteye.com/blog/750326
oracle误删除表数据后的恢复详解.doc
为了使 Oracle 数据库从任何逻辑误操作中迅速地恢复,Oracle 推出了闪回技术。 该技术首 先以闪回查询( Flashback Query)出现在 Oracle 9i 版本中,后来 Oracle 在 10g 中对该技术 进行了全面扩展,提供了闪回...
原创Oracle 物理删除数据文件恢复 危机演练
oracle中数据delete且commit 恢复误删数据
【总结】oracle恢复误删除数据,解除锁定的等sql语句.doc
Oracle误删的重要数据恢复指导中给出的是如果错误删除了一些中的的数据的找回方法和以后避免此类情况的注意事项的说明
因自己前段时间因truncate一张表无法找回,且数据超过60W,平常的企业软件超过1W收费,故整理此内容,希望和我遇到同样问题的新手有帮助
利用oracle闪回技术恢复数据,在因误操作导致删除数据时,可以进行数据恢复。
利用oracle提供的闪回方法,如果在删除数据后还没做大量的操作(只要保证被删除数据的块没被覆写),就可以利用闪回方式直接找回删除的数据。
oracle 恢复表数据 可以恢复刚删除的数据
Oracle数据库误删除数据的不同恢复方法整理(超级实用)
oracle误删数据恢复。利用ORACLE回闪功能时间点克查询删除前的数据,如何恢复就看自己了哈
pl/sql,Oracle数据库中,不小心delete数据并提交后如何恢复被删数据? 提供了两种办法