您的位置:首页 > 数据库 > Oracle

oracle数据被误删或更新的恢复方法

2016-03-16 09:40 676 查看
http://blog.sina.com.cn/s/blog_638adf340101prkt.html

采用oracle的基于时间查询as of timestamp的办法进行恢复数据。

查询到3分钟前表的数据:

SELECT *
FROM table AS OF TIMESTAMP SYSDATE
- 3/1440




通过ID关联的方式更新回去即可。如下:

update
table t1

set t1.parameter =

(select parameter

from
table 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查询出来的数据存到新表中,再进行恢复操作,因为这样数据不再受时间差的影响,确保数据是准确的,无论你何时开始做恢复操作。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  oracle