Oracle数据库误操作数据后及时恢复

今天在操作数据库时一不小心把用sql语句把表中某列数据给清空了,抓紧时间从网上找到资料进行恢复,经过几分钟操作后数据倒是恢复了,但是表中的数据排列顺序发生了变化,和原表数据排列顺序不一致了,于是记录一下。并不是所有的数据库版本都可以恢复,本人使用的是Oracle 12C)
由于删除/更新/插入恢复步骤相同,本人只记录更新的操作步骤;

第一步:还原误操作步骤

正常表数据如图:
在这里插入图片描述
在PLSQL中执行了这句sql并提交事务后,突然发现更新错了,将value_name这个字段的值清空了;(执行的sql为: update common_informa set value_name = ’ ’ )

第二步:根据时间戳来进行恢复 (只用执行2.1 、2.2 、2.3 这3步即可)

–2.1 假设当前距离删除数据时已过去20分钟左右的时间,执行SELECT查询语句,并附加AS OF子句,执行发现20分钟以前的数据还是正常的,那么我们就用20分钟以前的数据来恢复(1440解释:首先60(分)×24=1440,这样就计算出一天拥有多少分钟,SYSDATE是系统函数,用来取得当前的系统时间(以天为单位)SYSDATE-20/1440,得出的就是距当前时间20分钟前的记录了。);

 SELECT  *  FROM 要恢复数据的表名 AS OF TIMESTAMP  SYSDATE-20/1440;     
 或  
 SELECT  *  FROM 要恢复数据的表名 AS OF TIMESTAMP to_date('2018-12-17 15:33:00', 'YYYY-MM-DD HH24:MI:SS');

– 2.2 开启数据行移动

ALTER TABLE  要恢复数据的表名  ENABLE ROW MOVEMENT;

– 2.3 数据恢复的关键语句(执行这句sql时,可能会报错 ‘未开启数据的行移动’,那么我们去执行上一句2.2的sql,执行完后再来执行此句,即可完成恢复),执行完此sql数据就已经恢复了。

FLASHBACK TABLE  要恢复数据的表名  TO TIMESTAMP SYSDATE-20/1440;
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值