Oracle 短时间内误删数据,如何快速找回?(UNDO)

举报
Lucifer三思而后行 发表于 2021/10/31 17:44:52 2021/10/31
【摘要】 首先,这个短时间内,通常是值 undo 段没有被覆盖,undo 保留的时间为多长呢?1、需要看 undo_retention 的设置,默认为 900s,也就是 15 分钟。2、需要看数据库的业务繁忙程度,如果1天切一个归档那种,3天前删的说不定都能用 UNDO 找回来。好的,科普完了!如果,两分钟前不小心误删了一笔数据,如何快速找回?1、查看 UNDO 中 5 分钟前数据是否还在select...

首先,这个短时间内,通常是值 undo 段没有被覆盖,undo 保留的时间为多长呢?

1、需要看 undo_retention 的设置,默认为 900s,也就是 15 分钟。
2、需要看数据库的业务繁忙程度,如果1天切一个归档那种,3天前删的说不定都能用 UNDO 找回来。

好的,科普完了!

如果,两分钟前不小心误删了一笔数据,如何快速找回?

1、查看 UNDO 中 5 分钟前数据是否还在

select * from 用户.as of timestamp to_timestamp('2021-09-12 10:30:00', 'yyyy-mm-dd hh24:mi:ss');

2、防止 UNDO 中数据被覆盖,先创建一张备份表将5分钟前数据备份

create table 用户.表_20201217
as
select * from 用户.as of timestamp to_timestamp('2021-09-12 10:30:00', 'yyyy-mm-dd hh24:mi:ss');

3、用备份表和原表比对数据,将误删的数据插入原表中

没有sql,自己搞吧!可以用 PLSQL等工具导出!

注意:此方法仅适用于 delete 等 DML 误删误操作恢复,DDL 不支持!


本次分享到此结束啦~

如果觉得文章对你有帮助,点赞、收藏、关注、评论,一键四连支持,你的支持就是我创作最大的动力。

❤️ 技术交流可以 关注公众号:Lucifer三思而后行 ❤️

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。