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) 保存历史数据。
相关推荐
-SGlow-3 小时前
MySQL相关概念和易错知识点(2)(表结构的操作、数据类型、约束)
linux·运维·服务器·数据库·mysql
♡喜欢做梦6 小时前
【MySQL】深入浅出事务:保证数据一致性的核心武器
数据库·mysql
遇见你的雩风6 小时前
MySQL的认识与基本操作
数据库·mysql
dblens 数据库管理和开发工具6 小时前
MySQL新增字段DDL:锁表全解析、避坑指南与实战案例
数据库·mysql·dblens·dblens mysql·数据库连接管理
weixin_419658316 小时前
MySQL的基础操作
数据库·mysql
不辉放弃7 小时前
ZooKeeper 是什么?
数据库·大数据开发
Goona_7 小时前
拒绝SQL恐惧:用Python+pyqt打造任意Excel数据库查询系统
数据库·python·sql·excel·pyqt
程序员编程指南8 小时前
Qt 数据库连接池实现与管理
c语言·数据库·c++·qt·oracle
幼儿园老大*10 小时前
数据中心-时序数据库InfluxDB
数据库·时序数据库