一不小心将数据库数据修改了,而且回滚无效,于是去尝试各种方法恢复数据,最后实测这个方法可以实现

查询到修改时间点之前的数据

恢复数据

恢复数据库被修改数据的流程及代码,这里被修改的表是AUTH_USER,实际应用填写对应表名。
恢复方法学习自博客:
修复代码:
-- 通过时间恢复删除且已提交的数据
-- 1)查询当前系统时间
select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual;
-- 2)查询删除数据的时间点之前的数据
select * from AUTH_USER as of timestamp to_timestamp('2023-09-06 14:51:37','yyyy-mm-dd hh24:mi:ss');
--(如果不是,则继续缩小范围)
-- 3)恢复删除且已提交的数据
--开启行移动功能(解决执行以下语句报错问题)
alter table AUTH_USER enable row movement;
--恢复某个时间点的数据
flashback table AUTH_USER to timestamp to_timestamp('2023-09-06 14:51:37','yyyy-mm-dd hh24:mi:ss');
--关闭行移动功能
alter table AUTH_USER disable row movement;
补充内容
后续蒋老师补充了一些内容:
通过时间进行恢复固然可以将数据恢复到指定时间点,但是操作期间产生的数据和被修改的数据无法体现,正确的做法是将当前数据拷贝一份另存新表,再进行数据恢复,将恢复后的数据和拷贝数据进行对比合并(前提是恢复时间足够短或者数据不常发生变动)。
Oracle数据恢复:误删后找回AUTH_USER表至特定时间点的方法

本文介绍了在Oracle数据库中,如何通过查询和使用闪回功能恢复AUTH_USER表误删的数据,以及蒋老师的补充建议,即备份当前数据并对比恢复后的结果。
https://blog.youkuaiyun.com/ye43191/article/details/130594728
606

被折叠的 条评论
为什么被折叠?



