当前位置: 首页 > 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.lryc.cn/news/600473.html

相关文章:

  • ClickHouse高性能实时分析数据库-高性能的模式设计
  • 学习随想录-- web3学习入门计划
  • 50道JavaScript基础面试题:从基础到进阶
  • haproxy原理及实战部署
  • 根本是什么
  • 统计学07:概率论基础
  • Chukonu 阅读笔记
  • 分类预测 | MATLAB实现DBO-SVM蜣螂算法优化支持向量机分类预测
  • 深入解析YARN中的FairScheduler与CapacityScheduler:资源分配策略的核心区别
  • 检索召回率优化探究一:基于 LangChain 0.3集成 Milvus 2.5向量数据库构建的智能问答系统
  • 微信小程序 自定义带图片弹窗
  • 数据存储:OLAP vs OLTP
  • Flutter实现Retrofit风格的网络请求封装
  • Apache Doris Data Agent 解决方案:开启智能运维与数据治理新纪元
  • RS485转Profinet网关配置指南:高效启动JRT激光测距传感器测量模式
  • React入门学习——指北指南(第四节)
  • SQL Developer Data Modeler:一款免费跨平台的数据库建模工具
  • Flutter 提取图像主色调 ColorScheme.fromImageProvider
  • Javaweb————HTTP消息体拆分讲解
  • 渗透艺术系列之Laravel框架(一)
  • 互联网应用主流框架整合 Spring Boot开发
  • 大模型——字节Coze重磅开源!Dify何去何从
  • 车载诊断刷写 --- Flash关于擦除和写入大小
  • 解决VSCode中Github Copilot无法登陆的问题
  • AI Agent开发学习系列 - LangGraph(1): 用LangGraph创建我们的第一个Agent
  • 强化学习(第三课第三周)
  • 在一个存在的包里面编写msg消息文件
  • (二)使用 LangChain 从零开始构建 RAG 系统 RAG From Scratch
  • Ubuntu22.04提示找不到python命令的解决方案
  • [Linux入门] 初学者入门:Linux DNS 域名解析服务详解