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) 保存历史数据。
相关推荐
l1t几秒前
利用docker在windows 11 wsl中安装oracle 12cR2
运维·windows·docker·oracle·容器
gugugu.1 分钟前
Redis持久化机制详解(一):RDB全解析
数据库·redis·缓存
暗之星瞳15 分钟前
mysql表的链接
大数据·数据库·mysql
陌路2018 分钟前
redis持久化篇AOF与RDB详解
数据库·redis·缓存
@老蝴25 分钟前
MySQL - 索引
数据库·mysql
tgethe34 分钟前
MySQL 进阶攻略
数据库·mysql
亮子AI36 分钟前
【node.js MySQL】node.js 如何连接 MySQL?
数据库·mysql·node.js
程序员根根38 分钟前
Web 开发必学:Java 数据库操作从 JDBC 到 MyBatis 的进阶之路
数据库·后端
全栈工程师修炼指南39 分钟前
Nginx | HTTPS 加密传输:Nginx 反向代理与上游服务 SSL 双向认证实践
网络·数据库·nginx·https·ssl
德迅云安全-小潘40 分钟前
网络空间资产安全发展演进与实践框架
数据库·web安全