Oracle 误删数据恢复

今天后台调整数据时误删了一批数据,没有备份数据,差点要删库跑路了,幸好同事大神告诉一种方法可以查询近期的某个历史节点的数据。既可以用来恢复误操作的数据,也可以用来对比历史数据测试代码效果,记录一下备用。Oracle 的闪存查询(Flashback Query)是一种利用 UNDO 数据 来查看过去某个时间点或 SCN(系统变更号)时的数据状态的技术,常用于数据恢复、审计或误操作回退。

✅ 核心用法

1. 查询某个时间点的数据
sql 复制代码
SELECT * FROM 表名
AS OF TIMESTAMP TO_TIMESTAMP('2025-07-25 08:30:00', 'YYYY-MM-DD HH24:MI:SS');
2. 查询某个 SCN 的数据
sql 复制代码
SELECT * FROM 表名 AS OF SCN 13526973;
3. 恢复误删数据
sql 复制代码
CREATE TABLE 表名_bak AS
SELECT * FROM 原表 AS OF TIMESTAMP TO_TIMESTAMP('2025-07-25 08:30:00', 'YYYY-MM-DD HH24:MI:SS');

示例:某医院误删了 8:30--9:00 的数据,使用如下方式恢复:

sql 复制代码
SELECT * FROM reportinfo AS OF SCN 13526973;

⚠️ 注意事项

项目 说明
UNDO_RETENTION 默认只保留 15 分钟,超过可能报 ORA-01555: snapshot too old
归档日志 闪回查询不依赖归档日志,依赖的是 UNDO 表空间
权限要求 需要有 FLASHBACK 权限或 SELECT ANY TRANSACTION 权限。

✅ 适用场景

  • 误删或误改数据后快速找回;
  • 审计数据变更历史;
  • 无需恢复整个数据库的"轻量级"回退。

如需更长时间窗口的闪回,建议:

  • 增加 UNDO_RETENTION 参数;
  • 使用 闪回数据归档(Flashback Data Archive) 保存历史数据。
相关推荐
ST.J6 分钟前
SQL与数据库笔记
数据库·笔记·sql
HCIE考证研究所7 分钟前
OCA、OCP、OCM傻傻分不清?Oracle认证就看这篇
oracle
jllws11 小时前
数据库原理及应用_数据库管理和保护_第5章数据库的安全性_理论部分
数据库
2302_809798321 小时前
【Redis】缓存的穿透、击穿和雪崩
数据库·redis·缓存
花哥码天下3 小时前
MySQL事务日志类型及作用解析
数据库·mysql
手握风云-3 小时前
MySQL数据库精研之旅第十七期:深度拆解事务核心(下)
数据库·mysql
亮子AI3 小时前
【PostgreSQL】如何实现主从复制?
数据库·postgresql
杏花春雨江南3 小时前
可重复读 是否“100%”地解决幻读?
数据库·mysql
曹牧3 小时前
Oracle:select top 5
数据库·sql·oracle