恢复ORACLE被误更新或删除数据的办法
来源:互联网 发布:阿里云企业邮箱 pop 编辑:程序博客网 时间:2024/05/28 23:11
转:http://www.tuicool.com/articles/MfQJ3u
有时候我们在操作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查询出来的数据存到新表中,再进行恢复操作,因为这样数据不再受时间差的影响,确保数据是准确的,无论你何时开始做恢复操作。
- 恢复ORACLE被误更新或删除数据的办法
- 恢复ORACLE被误更新或删除数据的方法
- 恢复ORACLE被误更新或删除数据的方法
- 恢复oracle被误更新数据的办法
- 如何恢复oracle误删除、更新、插入的数据
- oracle误删数据的恢复办法
- Oracle 恢复已删除数据办法
- oracle 使用flashback(闪回)恢复误删除的数据 或 误删除的表
- oracle 使用flashback(闪回)恢复误删除的数据 或 误删除的表
- oracle数据误删除,更新时恢复数据
- oracle数据被误删或更新的恢复方法
- ORACLE误删除数据的恢复方法
- oracle误删除数据后的恢复
- ORACLE误删除数据的恢复方法
- oracle误删除数据的恢复方法
- oracle误删除数据的恢复方法
- oracle误删除数据的恢复方法
- oracle误删除数据的恢复方法
- Table被web编程弃用的原因?
- 深度学习国外经典教程——大师带你入门(视频、PPT讲稿)
- 《Erlang 程序设计》练习答案 -- 第八章 顺序编程补遗
- 面向业务的立体化高可用架构设计
- SecureCRT中文显示乱码
- 恢复ORACLE被误更新或删除数据的办法
- 在 CentOS 6.7 上配置 Cisco AnyConnect VPN
- 提升页面转化率100招
- 自定义布局
- 堆栈
- jquery操作select下拉框的多种方法(选中,取值,赋值等) 转载
- 泊松融合
- 技术进步与管理创新
- 【Hibernate】Hibernate多表查询后,将查询结果转化为实体