首先,这个短时间内,通常是值 undo 段没有被覆盖,undo 保留的时间为多长呢?
1、需要看 undo_retention 的设置,默认为 900s,也就是 15 分钟。
2、需要看数据库的业务繁忙程度,如果1天切一个归档那种,3天前删的说不定都能用 UNDO 找回来。
好的,科普完了!
如果,两分钟前不小心误删了一笔数据,如何快速找回?
1、查看 UNDO 中 5 分钟前数据是否还在
select*from用户.表asoftimestampto_timestamp('2021-09-12 10:30:00', 'yyyy-mm-dd hh24:mi:ss');
2、防止 UNDO 中数据被覆盖,先创建一张备份表将5分钟前数据备份
createtable用户.表_20201217asselect*from用户.表asoftimestampto_timestamp('2021-09-12 10:30:00', 'yyyy-mm-dd hh24:mi:ss');
3、用备份表和原表比对数据,将误删的数据插入原表中
没有sql,自己搞吧!可以用 PLSQL等工具导出!
注意:此方法仅适用于 delete 等 DML 误删误操作恢复,DDL 不支持!