今天在操作数据库时一不小心把用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;