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) 保存历史数据。
相关推荐
IvorySQL4 分钟前
PostgreSQL 19 重磅新语法终于补齐这个缺口
数据库·postgresql·开源
IvorySQL11 分钟前
PostgreSQL 技术日报 (3月23日)|使用 rdtsc 减少 EXPLAIN ANALYZE 的计时开销
数据库·postgresql·开源
yhole23 分钟前
SQL中的REGEXP正则表达式使用指南
数据库·sql·正则表达式
IvorySQL28 分钟前
PostgreSQL 技术日报 (3月21日)|这些机制,可能并非 “ 理所当然 ”
数据库·postgresql·开源
m0_5180194837 分钟前
使用Seaborn绘制统计图形:更美更简单
jvm·数据库·python
卓怡学长1 小时前
m280本科生导师指导平台
java·数据库·spring·tomcat·maven·intellij-idea
大尚来也1 小时前
Serverless架构深度解析:适用场景、核心局限与破局之道
数据库
Wave8451 小时前
非阻塞按键(单击,双击,长按)
数据库
2401_831824961 小时前
为你的Python脚本添加图形界面(GUI)
jvm·数据库·python
久违的太阳1 小时前
记录一次ORACLE RAC安装PSU补丁步骤
数据库·oracle