当前位置: 首页 > news >正文

Oracle 误删数据恢复

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

✅ 核心用法

1. 查询某个时间点的数据
SELECT * FROM 表名
AS OF TIMESTAMP TO_TIMESTAMP('2025-07-25 08:30:00', 'YYYY-MM-DD HH24:MI:SS');
2. 查询某个 SCN 的数据
SELECT * FROM 表名 AS OF SCN 13526973;
3. 恢复误删数据
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 的数据,使用如下方式恢复:

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) 保存历史数据。
http://www.dtcms.com/a/299663.html

相关文章:

  • BGP路由协议-LOCAL_PREF、AS_PATH和MED等属性
  • 【科研绘图系列】R语言绘制误差连线散点图
  • 知识图谱的初步探索
  • Nuxt 4:前端开发的全新篇章
  • 不正确的 clone() 方法实现与修复方案
  • 全能扩展,经济高效| 触想新款工控机化身工业自动化应用多面帮手
  • uniapp 自定义tab栏切换
  • RoPE:相对位置编码的旋转革命——原理、演进与大模型应用全景
  • 【C/C++】explicit_bzero
  • windows安装mysql8缺少时区信息
  • C语言开发工具Win-TC
  • Flask input 和datalist结合
  • C语言数据结构笔记6:函数指针的使用
  • 5. 流程控制语句
  • 哈希指针与数据结构:构建可信数字世界的基石
  • 记一次腾讯云临时密钥接管存储桶
  • obd运维OceanBase数据库的常见场景
  • C++11特性详解(上)
  • 解决使用vscode连接服务器出现“正在下载 VS Code 服务器...”
  • 实现网页访问/接口调用KernelMemory
  • cacti的命令执行和回显
  • 八股文整理——计算机网络
  • 【数据结构】队列和栈练习
  • HTTPS的基本理解以及加密流程
  • Nestjs框架: 基于Mongodb的多租户功能集成和优化
  • 顶顶通呼叫中心系统之创建与注册分机
  • 矩阵乘法计算
  • 安德鲁·卡帕西:深入探索像ChatGPT这样的大语言模型
  • 免费 PDF 转 Word 工具:无水印 / 支持批量转换,本地运行更安全【附工具下载】
  • Ubuntu系统 系统盘和数据盘扩容具体操作