Oracle体系结构初探:闪回技术

在Oracle体系结构初探这个专栏中,已经写过了REDO、UNDO等内容。觉得可以开始写下有关备份恢复的内容。闪回技术 — Oracle数据库备份恢复机制的一种。它可以在一定条件下,高效快速的恢复因为逻辑错误(误删误更新等)导致的数据丢失、错乱等问题。

在我所见过的实际生产例子中,很少会选择闪回技术作为一整套的备份恢复方案基础;闪回技术更多的是应用于误删误更新了某些数据后,在避免大动干戈进行备份还原恢复的情况下,进行快速数据恢复。

所以本篇文章也不想长篇大论闪回的每个细节,更多是想结合实际生产去和大家分享下闪回技术的使用。

目录

闪回技术前提需知

常用闪回技术必备

Ⅰ:闪回DROP操作

Ⅱ:闪回至过去某时间点

Ⅲ:闪回查询

闪回时间点查询

闪回版本查询 

闪回事务查询 

Ⅳ:闪回事务

其他闪回技术了解


闪回技术前提需知

  • 只闪回逻辑错误(缺陷)

Oracle的闪回只能闪回逻辑错误;对于数据文件损坏等类似的错误,闪回操作是无能为力的。所以对于正式生产来讲,闪回技术不能作为正式的备份方案技术基础。

  • 受限于undo (缺陷)

大部分的闪回技术都是依赖于undo段中的undo数据。关于undo,前面有篇文章已经讲述过了(聊聊undo)。如果要恢复的数据超过了undo大小或者保留时效,那闪回此时也无能为力。

举个例子:

我不小心删除了某个表的数据,当时不知道该怎么做;过了俩钟头,有人对我说,可以闪回,此时该表的在两个小时前的数据早已被覆盖过期,闪回无能为力。

  • 一般不能跨越DDL

例如闪回查询、闪回至过去某时间点、闪回事务等,如果表结构发生了变动,闪回技术则无效。

  • 恢复耗时短(优势)

相比较Oracle的RMAN等恢复技术手段,Oracle的闪回技术可以在非常短时间内恢复数据错误。而进行RMAN还原恢复的话,受限于RMAN备份时的文件大小,恢复耗时的成本可能就很高了。

  • 精准恢复(优势)

在生产上,常常可能在测试时,删除了某张表真实的业务数据且提交;此时运用闪回技术可以快速定位此表进行数据闪回。如果用RMAN等手段的话,因为RMAN的备份策略一般都不会针对某张表进行备份,基本是针对数据文件或者数据库进行备份;此时如果进行还原恢复,就得把整个数据文件甚至整个表空间进行还原恢复,这非常有可能影响到数据库其他表的数据内容。

常用闪回技术必备

Ⅰ:闪回DROP操作

这里的闪回表针对的是 DROP TABLE TABLE_NAME 操作。

在掌握闪回表技术前,需要先了解Oracle的另一个知识点:recyclebin(回收站)。

凡是通过DROP操作删除的表,如果没有在操作代码中加purge,是没有被彻底删除的。被DROP掉的表都进入了Oracle的回收站,所以这让我们可以恢复因误用DROP操作导致的数据问题。且现在的Oracle数据库都是默认开启recyclebin的。

下面是关于回收站的基础介绍:

1、查看回收站是否开启

value为on即为开启,但其实现在的Oracle都是默认开启的。

show parameter recyclebin

2、查看回收站内容

查询 dba_recyclebin 系统表

SELECT * FROM dba_recyclebin;

或者

在对应用户下 show recyclebin

show recyclebin

3、清空回收站

purge recyclebin;

4、彻底删除一张表

DROP TABLE TABLE_NAME PURGE

了解完回收站,可以开始进行闪回表操作了。

闪回SQL如下:

flashback table "BIN$F/CHkjSxeqLgY1g7qMByIw==$0" to before drop;

闪回步骤如下图:

闪回步骤

 至此大家可以看到被DROP的表被闪回了,此时回收站也没有这个表的内容了哦!

Ⅱ:闪回至过去某时间点

扯句闲话,看过周杰伦的《大灌篮》没有?电影结尾,方世杰的球队因为裁判骚操作输了;方世杰一招乾坤大挪移把时间挪回比赛结束前,一记三分线外接力灌篮,方世杰球队又赢了。

当时就觉得,能逆转时间,真的牛叉。现在,Oracle的闪回技术就支持将表数据逆转到过去的某个时间点。

下面通过一个例子和大家分享Oracle的闪回如何 “逆转时间“。

1、时间 :2024-05-08 09:01:00 

我对 HR.RO 表 执行了批量 DELETE 操作,且提交。

DELETE FROM hr.ro WHERE others is null;

2、时间 :2024-05-08 09:05:00 

领导跑来质问我:你把 hr.ro 表 others 字段 为 NULL 的都删了?你他喵删错了,应该是删掉不为NULL的值。

3、时间 :2024-05-08 09:05:30

我气定神闲:多大点事儿嘛!再给你恢复行了吧 ╮(╯▽╰)╭

4、时间 :2024-05-08 09:06:00

于是我表面稳定内心慌的一批的执行了如下操作

开启hr.ro表的行移动

ALTER TABLE hr.ro ENABLE ROW MOVEMENT;

闪回hr.ro表 到删除前时间点

flashback table hr.ro to timestamp to_date('2024-05-08 09:00:59','yyyy-mm-dd hh24:mi:ss');

关闭hr.ro表行移动

ALTER TABLE hr.ro DISABLE ROW MOVEMENT;

5、此时 hr.ro 表的数据恢复到 2024-05-08 09:00:59 这个时间点时的状态,数据逆转成功。

将表闪回至过去某个时间点的操作并不复杂,但有几点大家一定要注意!

  • 注意场景!

这张表可能不止您一个人在操作,可能在此期间还有其他用户进行了操作;如果闪回会把其他用户在此期间的操作给搞没。所以谨慎使用,确保您的当下场景合适,再使用此操作!

举个例子,有次我使用闪回到过去某个时间点的操作。使用场景是该Oracle数据库是用来存储数据仓库的DW层数据;有同事误将某张表的历史数据删除了;但对于该表当天的数据而言,是通过ETL实时同步的,所以我可以放心的使用该闪回操作,不必担心有其他影响。

  • 受限undo

这种闪回到过去的某个时间点的操作,都是使用undo中的前镜像数据。Oracle默认的undo保留时间是900s,超过这个时间,undo空间还够的话,就会继续保留;undo空间如果不够,不到900s也会把该undo数据覆盖掉。这个时候想闪回都没地方闪回了。如果delete或者update的数据量太大,甚至超过了undo表空间,那就只能闪回一部分数据了,不能闪回所有。

Ⅲ:闪回查询

闪回查询又分为三种查询方式:闪回时间点查询、闪回版本查询、闪回事务查询;下面分别对这三种查询进行说明。

  • 闪回时间点查询

可以在undo数据有效期内,查询过去某个时间点的表数据。

闪回SQL如下:

select * FROM hr.ro as of timestamp to_timestamp('2024-05-08 20:37:00', 'yyyy-mm-dd hh24:mi:ss') where req_no = 'A1';

下面是操作例子:

闪回时间点查询
  • 闪回版本查询 

可以查询存在于两个时间点或两个SCN之间的所有行的版本。

查询SQL如下:

select 
versions_startscn, 
versions_endscn, 
versions_xid, 
versions_operation,
req_no, --业务表字段
others  --业务表字段
from hr.ro 
versions between timestamp 
to_timestamp('2024-05-09 22:16:00', 'yyyy-mm-dd hh24:mi:ss') 
and 
to_timestamp('2024-05-09 22:19:59', 'yyyy-mm-dd hh24:mi:ss')
where req_no = 'A2';

下面是操作例子:

其中有几个需要注意的点:

① 仅查询已提交的数据

② 不能用于查询外部表,临时表或视图

③ 无法跨越DDL命令

PS:做这个例子的时候,我花了半小时;最后发现自己傻逼的把虚拟机时间调到了第二天,导致一直查不出来  /(ㄒoㄒ)/~~(所以这也是为什么Oracle使用scn号记录标识数据库变化,而不是时间,因为操作系统时间有可能是错的)

  • 闪回事务查询 

先给使用的用户赋予查询事务的权限

grant select any transaction to HR;

开启补充日志

alter database add supplemental log data;

查询补充日志是否开启

SELECT db.supplemental_log_data_min db FROM v$database db;
--返回YES,即开启

 查询SQL

select 
ftq.xid,
ftq.operation,
ftq.table_name,
ftq.table_owner,
ftq.row_id,
ftq.start_scn,
to_char(ftq.start_timestamp,'YYYY-MM-DD HH24:MI:SS') AS start_timestamp,
ftq.commit_scn,
to_char(ftq.commit_timestamp,'YYYY-MM-DD HH24:MI:SS') AS commit_timestamp,
ftq.undo_sql --不开启补充日志,此字段是空值
from flashback_transaction_query ftq 
where ftq.logon_user = 'HR' --使用的用户

以下是一个模拟测试:

1、测试表 hr.ro

2、更新忘记加where条件(已提交)

update hr.ro set others = 'traquery'; 

3.1、先通过闪回版本查询,查询到对应事务的xid

SELECT req_no,  --业务表字段others,  --业务表字段to_char(versions_starttime, 'YYYY-MM-DD HH24:MI:SS') versions_starttime,to_char(versions_endtime, 'YYYY-MM-DD HH24:MI:SS') versions_endtime,versions_startscn,versions_endscn,versions_xid,versions_operationFROM hr.ro versions BETWEEN TIMESTAMP minvalue AND maxvalueORDER BY versions_starttime;

结果集如下:

3.2、通过事务xid,查询到对应的undo_sql,看到底发生了什么

select 
ftq.xid,
ftq.operation,
ftq.table_name,
ftq.table_owner,
ftq.row_id,
ftq.start_scn,
to_char(ftq.start_timestamp,'YYYY-MM-DD HH24:MI:SS') AS start_timestamp,
ftq.commit_scn,
to_char(ftq.commit_timestamp,'YYYY-MM-DD HH24:MI:SS') AS commit_timestamp,
ftq.undo_sql
from flashback_transaction_query ftq 
where ftq.logon_user = 'HR'
and ftq.xid = '010013006D050000'

查询结果集如下,可以发现是什么时候,发生了什么操作。

如果想揪出谁做的这个操作,可以通过xid去查询会话动态性能视图,查看是哪个主机干的哦。

Ⅳ:闪回事务

前面讲过了闪回至过去某时间点的操作,也说了这个操作有风险,可能会把别的用户提交的事务给一起咔擦了。闪回事务与之相比风险就小很多了,但风险也不是0。

为啥不是0呢?在这个专栏的 网络管理 和 session与process 两篇文章中都描述了Oracle的事务。对于一个事务A所操作的行数据,很有可能另一个事务B也对此行数据进行了操作;如果闪回了事务A,那么就会影响到事务B。

当然如果您觉得当下场景对于此事务之间的关系无所谓,不在乎事务A之后有多少事务进行了操作,只想将数据返回到事务A发生之前的状态,那就可以进行闪回。

操作如下:

① 在闪回事务查询的基础上,闪回事务需要再打开一个主键补充日志。

alter database add supplemental log data (primary key) columns;

② 通过SQL闪回事务需要使用到Oracle的程序包,所以需要增加用户的 dbms_flashback 的执行权限。

grant execute on dbms_flashback to HR;

③ 通过闪回版本查询,查询到需要闪回的事务的XID。

④ 通过 dbms_flashback.transaction_backout 执行闪回事务。

declarexids sys.xid_array;beginxids := sys.xid_array('01000A006F050000');dbms_flashback.transaction_backout(1,xids,options=>dbms_flashback.cascade);end;

xids := sys.xid_array('01000A006F050000');

数组内容,这里是填写xid,可以填写多个或1个。

dbms_flashback.transaction_backout(1,xids,options=>dbms_flashback.cascade);

这里的 1 指的是xid数量;

这里的 xids 指的是容纳xid的集合变量,就是在declare声明下面定义的那个;

这里的 options=>dbms_flashback.cascade 是参数选项,包含下面几个参数:

  • NOCASCADE 

翻译下就是要闪回的事务不能和其他事务扯上关系,不然闪回GG;

  • CASCADE

翻译下就是管你这几个事务有没有关系,直接级联闪回;

  • NOCASCADE_FORCE

翻译下就是,比如有 A B两个事务有关系,忽略B,闪回A,如果没有约束错误(比如主键冲突啊)就能成功,否则GG;

  • NONCONFILICT_ONLY

翻译下就是,比如有 A B两个事务有关系,闪回A,别影响B,否则GG;

其他闪回技术了解

除了以上的闪回技术外,Oracle还提供了以下技术:

  • 闪回归档
  • 闪回数据库

这俩技术我没有用过;因为在备份恢复体系中,我也没见过哪个项目用过这俩技术。因为不熟悉,也就不多写这块内容。大家权当听个响,有兴趣的可以去查下资料玩一玩。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/9783.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

岩点×数说故事×小红书 | 发布《中国攀岩行业分析报告》

从下班健身到下班攀岩,从“鸡娃”到岩馆“溜娃”,被奥运“正名”的攀岩运动,在国内熬过了萌芽阶段,悄然开出了花。2023年,各类重磅攀岩赛事重启、线下岩馆疯狂扩张,小众攀岩正式进入大众视野,风…

249 基于matlab的MED、OMEDA、MOMEDA、MCKD信号处理方法

基于matlab的MED、OMEDA、MOMEDA、MCKD信号处理方法。最小熵反褶积(MED),最优最小熵反卷积调整卷积 (OMEDA),多点最优最小熵解卷积调整(Multipoint Optimal Minimum Entropy Deconvolution Adjusted,MOMEDA),最大相关峭…

Vue2 组件通信方式

props/emit props 作用&#xff1a;父组件通过 props 向子组件传递数据parent.vue <template><div><Son :msg"msg" :pfn"pFn"></Son></div> </template><script> import Son from ./son export default {name: …

winform图书管理系统

winform图书管理系统说明文档 运行前附加数据库.mdf&#xff08;或sql生成数据库&#xff09; 主要技术&#xff1a; 图书管理员 读者管理 图书管理 添加 修改 删除 查看 入库 书册列表 书册管理用户管理退出 借书 还书 系统管理员 修改图书管理权限 项目获取&#xff1a;…

LeetCode 209 长度最小的子数组(滑动窗口and暴力)

、 法一&#xff1a;滑动窗口 //使用滑动窗口来解决问题 //滑动窗口的核心点有&#xff1a; /*1.窗口内是什么&#xff1f;2.如何移动窗口的起始位置&#xff1f;3.如何移动窗口的结束位置&#xff1f;4.两个指针&#xff0c;怎么判断哪个指针是终止指针&#xff0c;哪个指针…

代码随想录算法训练营第六十天| LeetCode647. 回文子串 、516.最长回文子序列

一、LeetCode647. 回文子串 题目链接/文章讲解/视频讲解&#xff1a;https://programmercarl.com/0647.%E5%9B%9E%E6%96%87%E5%AD%90%E4%B8%B2.html 状态&#xff1a;已解决 1.思路 这道题我只想出来了暴力解法&#xff0c;动规解法并没有想出来。根据视频讲解才把它想出来。…

C++——命名空间

c ——命名空间 前言一.命名空间命名空间的进一步拓展 二.io流特性 前言 ** 好久不见&#xff0c;甚是想念~今天我们讲解的是关于c命名空间的一些知识点&#xff0c;这只是开胃小菜哦&#xff0c;期待我们后面更深入知识的灵魂碰撞吧 ** 一.命名空间 怎么形容呢~命名空间出现…

Rocketmq如何保证消息不丢失和幂等性

生产者 生产者通过RocketMQ提供的事务消息&#xff08;两阶段提交&#xff09;能保证消息的一致性。 第一阶段给Broker发送一个半事务消息&#xff0c;半事务消息是不能消费的消息&#xff0c;broker已经收到生产者发送的消息&#xff0c;但是并未收到生产者的二次确认&#x…

JavaScript使用 BigInt

在 JavaScript 中&#xff0c;最大的安全整数是 2 的 53 次方减 1&#xff0c;即 Number.MAX_SAFE_INTEGER&#xff0c;其值为 9007199254740991。这是因为 JavaScript 中使用双精度浮点数表示数字&#xff0c;双精度浮点数的符号位占 1 位&#xff0c;指数位占 11 位&#xff…

2024C题生物质和煤共热解问题的研究 详细思路

背景 随着全球能源需求的不断增长和对可再生能源的追求&#xff0c;生物质和煤共热解作为一种潜在的能源转化技术备受关注。生物质是指可再生能源&#xff0c;源自植物和动物的有机物质&#xff0c;而煤则是一种化石燃料。** 在共热解过程中&#xff0c;生物质和煤在高温和缺氧…

unity基础(二)

debug方法 Debug.Log(" 一般日志 ");Debug.LogWarning(" 警告日志 ");Debug.LogError(" 错误日志 ");// Player Informationstring strPlayerName "Peter";int iPlayerHpValue 32500;short shPlayerLevel 10;long lAdvantureExp 1…

越秀城投·星汇城 | 看得再多,都不如实景现房更安心

对于大多数家庭而言&#xff0c;买房是人生大事。经历了前几年房企暴雷、楼盘停工烂尾的风波&#xff0c;“现房”成为买房人心中最安心的代名词。无需再等待&#xff0c;所见即所得。 越秀城投星汇城位于平度南部新城核芯片区&#xff0c;不仅享受区域发展的利好&#xff0c;…

vs2019 里 C++ 20规范的 string 类的源码注释

&#xff08;1&#xff09;读源码&#xff0c;可以让我们更好的使用这个类&#xff0c;掌握这个类&#xff0c;知道咱们使用了库代码以后&#xff0c;程序大致具体是怎么执行的。而不用担心程序出不知名的意外的问题。也便于随后的代码调试。 string 类实际是 库中 basic_strin…

基于JAVAEE的停车场管理系统(论文 + 源码)

【免费】基于JAVAEE的停车场管理系统.zip资源-CSDN文库https://download.csdn.net/download/JW_559/89292324 基于JAVAEE的停车场管理系统 摘 要 如今&#xff0c;我国现代化发展迅速&#xff0c;人口比例急剧上升&#xff0c;在一些大型的商场&#xff0c;显得就格外拥挤&…

每日两题 / 24. 两两交换链表中的节点 25. K 个一组翻转链表(LeetCode热题100)

24. 两两交换链表中的节点 - 力扣&#xff08;LeetCode&#xff09; 定义三个指针&#xff0c;交换前先保存ntnt指针为next->next&#xff0c;cur和next两个节点&#xff0c;然后将pre->next指向next 若pre为空&#xff0c;说明当前交换的节点为头两个节点&#xff0c;…

VM虚拟机安装调试(步骤如下图)

VM虚拟机安装调试 随着一顿安装操作&#xff0c;还有enter键敲下&#xff0c;出现如下界面。

实现MYSQL8.3.0 版本流量抓取

实现MYSQL8.3.0 版本流量抓取 根据测试需求&#xff0c;需要抓取MYSQL8.3.0流量包&#xff0c;使用wireshark 数据库客户端实现 安装数据库服务端 这里就不给详细操作方法&#xff0c; 网上教程一大堆&#xff0c;小编这里是最新的MYSQL 8.3.0版本 安装成功后&#xff0c;创…

Omnity 进展月报 | 2024.4.1-4.30

Omnity 大事摘要 1、Octopus 官宣升级为 Omnity。 2、Omnity 4月28号正式上线&#xff0c;实现BTC 和 ICP 之间跨链转账 Runes 资产。 3、为庆祝上线&#xff0c;以符文 HOPE•YOU•GET•RICH 为资产&#xff0c;发红包快速触达大量用户&#xff0c;体验跨链服务。 4、Omni…

【前端】前端数据本地化的多种实现方式及其优劣对比

前端数据本地化的多种实现方式及其优劣对比 在现代Web开发中&#xff0c;提高页面响应速度和改善用户体验是核心目标之一。数据本地化是其中一种实现方式&#xff0c;它通过在客户端存储数据来减少服务器请求&#xff0c;从而加快数据载入速度和改善用户的体验。本文将介绍前端…

26、Qt使用QFontDatabase类加载ttf文件更改图标颜色

一、图标下载 iconfont-阿里巴巴矢量图标库 点击上面的链接&#xff0c;在打开的网页中搜索自己要使用的图标&#xff0c;如&#xff1a;最大化 找到一个自己想用图标&#xff0c;选择“添加入库” 点击“购物车”图标 能看到刚才添加的图标&#xff0c;点击“下载代码”(需要…