今天后台调整数据时误删了一批数据,没有备份数据,差点要删库跑路了,幸好同事大神告诉一种方法可以查询近期的某个历史节点的数据。既可以用来恢复误操作的数据,也可以用来对比历史数据测试代码效果,记录一下备用。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) 保存历史数据。