快速掌握数据库闪回查看技巧 (如何查看数据库开启闪回)

数据库闪回是一种数据库恢复技术,它可以将数据库快速还原到过去的某个时间点,以便数据丢失时快速恢复数据。闪回技术可以快速查看数据库中的数据变化情况,以帮助数据库管理员进行故障排查和安全审计。本文将介绍如何快速掌握数据库闪回的查看技巧。

一、准备工作

在进行数据库闪回查看之前,需要先进行准备工作。必须确定数据库版本,Oracle数据库版本必须是10g以上。需要确认是否有数据库管理员权限,因为只有具有管理员权限的用户才能执行闪回操作。此外,还需要从备份中恢复数据库,以便进行查看。

二、使用Flashback Query

Flashback Query是Oracle数据库中用于查看数据历史记录的一种方法。它可以直接通过SQL语句查询历史数据,而无需使用备份文件。使用Flashback Query时,必须在查询语句前添加如下语句:

SELECT * FROM table_name as OF TIMESTAMP to_timestamp(‘2023-04-01 00:00:00’, ‘YYYY-MM-DD HH24:MI:SS’);

其中,table_name是要查询的表名,to_timestamp是要查询的时间戳。该语句将返回指定时间点之前的所有数据记录。

三、使用Flashback Transaction Query

Flashback Transaction Query是另一种查看数据历史记录的方法。它可以在一定时间段内查看数据的所有变化情况,包括INSERT、UPDATE、DELETE等操作。使用Flashback Transaction Query时,必须在查询语句前添加如下语句:

SELECT * FROM FLASHBACK_TRANSACTION_QUERY

WHERE XID IN (SELECT XID FROM FLASHBACK_TRANSACTION_QUERY

WHERE TIMESTAMP BETWEEN to_timestamp(‘2023-04-01 00:00:00’, ‘YYYY-MM-DD HH24:MI:SS’) AND to_timestamp(‘2023-04-02 00:00:00’, ‘YYYY-MM-DD HH24:MI:SS’))

ORDER BY TIMESTAMP;

该语句将返回指定时间段内所有数据变更的详细记录。

四、使用LogMiner

LogMiner是Oracle数据库中用于查看归档日志和在线日志的工具。它可以帮助管理员快速查找数据变更记录,从而进行必要的恢复操作。使用LogMiner时,必须先启用归档模式,以便产生归档日志。LogMiner还需要经过一定的配置,以便正确地解析日志。具体操作可以参考Oracle的官方文档。

五、使用DBMS_FLASHBACK包

DBMS_FLASHBACK包是Oracle数据库中的一个内置包,它可以用于进行闪回操作。使用DBMS_FLASHBACK包时,必须在SQL语句中添加如下语句:

SELECT * FROM table_name flashblack_table

AS OF TIMESTAMP to_timestamp(‘2023-04-01 00:00:00’, ‘YYYY-MM-DD HH24:MI:SS’);

该语句将返回指定时间点之前的所有数据记录,从而实现快速恢复操作。

六、注意事项

在使用数据库闪回技术进行查看操作时,需要注意以下几点:

1. 数据库闪回操作需要在管理员权限下进行,否则无法执行。

2. 数据库闪回操作会修改数据库状态,因此需要谨慎使用。

3. 数据库闪回操作仅适用于具有归档功能的数据库版本。

4. 数据库闪回操作不适用于数据损坏的情况,此时需要使用其他的恢复方法。

通过本文的介绍,我们可以了解到如何快速掌握数据库闪回的查看技巧。使用闪回技术可以帮助管理员快速查找数据变更记录,从而进行必要的故障排查和安全审计。对于数据库管理员来说,掌握闪回技术是非常重要的一项技能,也是数据库实践中不可或缺的一环。

相关问题拓展阅读:

Oracle闪回默认是关闭的,为什么在数据库打开后不能启用闪回功能?

首先关岩嫌岩闭数据库: shutdown immediate;

在粗御开启到mount状态:startup mount;

修者仔改闪回功能:alter database flashback on;

开启数据库:alter datebase open;

要在oracle数据库处于侍滑mount状态的时老改腊候才能启用或者关闭archivelog功能。

startup monut;

alter database archivelog;

然后歼培

alter database open;

Oracle10g数据库中闪回表特性剖析

Oracle i Database 推出了闪回查询选项的概念 以便检索过去某个时间点的数据 但它不能闪回 DDL 操作 如删除表的操作 唯一的恢复方法是在另一个数据库中使用表空间的时间点恢复 然后使用导出/导派基入或其他方法 在当前数据库中重新创建表 这一过程需要 DBA 进行大量工作并且耗费宝贵的时间 更不用说还要使用另一个数据库进行克隆 使用 Oracle Database g 中的闪回表特性 它使得被删除表的恢复过程如同执行几条语句一样简单 让我们来看该特性是如何工作的

  删除那个表!

  首先 让我们查看当前模式中的表

  

  

  SQL> select * from tab;TNAMETAYPE CLUSTERID

   RECYCLETEST TABLE

  现在 我们意外地删除了该表

  

  

  SQL> drop table recycletest;Table dropped

    现在让我们来查看该表的状态

  

  

  SQL> select * from tab;TNAME TAYPE CLUSTERID BIN$ LhcpndanfgMAAAAAANPw==$ TABLE

  表RECYCLETEST 已不存在 但是请注意出现新表BIN$ LhcpndanfgMAAAAAANPw==$ 这就是所发生的事情 被删除的表 RECYCLETEST 并没有完全消失 而是重命名为一个由系统定义的名称 它存在于同一个表空间中 具有与原始表相同的结构 如果在该表上定义了索引或触发器 则它们也被重命尘灶谨名 使用与表相同的命名规则 任何相关源(如过程)都失效 原始表的触发器和索引被改为放置在重命名的表 BIN$ LhcpndanfgMAAAAAANPw==$ 上 保持被删除表的完整对象结构

  表及其相关对象被放置在一个称为 回收站 的逻辑容器中 它类似于您 PC 机中的回收站 但是 对象并没有从它们原先所在的表空间中删除 它们仍然占用那里的空间 回收站只是一个列出被删除对象目录辩闷的逻辑结构 在 SQL*Plus 提示符处使用以下命令来查看其内容(您需要使用 SQL*Plus 来进行此操作)

  

  

  SQL> show recyclebinORIGINAL NAME RECYCLEBIN NAMEOBJECT TYPE DROP TIME RECYCLETESTBIN$ LhcpndanfgMAAAAAANPw==$ TABLE : : :

  结果显示了表的原始名称 RECYCLETEST 并显示了回收站中的新名称 该名称与我们看到的删除后所创建的新表名称相同 (注意 确切的名称可能因平台不同而不同 )为恢复该表 您所需要做的就是使用 FLASHBACK TABLE 命令

  

  

  SQL> FLASHBACK TABLE RECYCLETEST TO BEFORE DROP;FLASHBACK PLETE SQL> SELECT * FROM TAB;TNAME TAYPE CLUSTERID RECYCLETESTTABLE

  瞧!表毫不费力地恢复了 如果现在查看回收站 它将是空的 记住 将表放在回收站里并不在原始表空间中释放空间 要释放空间 您需要使用以下命令清空回收站

  

  

  PURGE RECYCLEBIN;

  但是如果您希望完全删除该表而不需要使用闪回特性 该怎么办?在这种情况下 可以使用以下命令永久删除该表

  

  

  DROP TABLE RECYCLETEST PURGE;

  此命令不会将表重命名为回收站中的名称 而是永久删除该表 就象 g 之前的版本一样

  管理回收站

  如果在该过程中没有实际删除表 — 因而没有释放表空间 — 那么当被删除的对象占用了所有空间时 会发生什么事?

  答案很简单 这种情况根本不会出现 当表空间被回收站数据完全占满 以至于必须扩展数据文件来容纳更多数据时 可以说表空间处于 空间压力 情况下 此时 对象以先进先出的方式从回收站中自动清除 在删除表之前 相关对象(如索引)被删除

  同样 空间压力可能由特定表空间定义的用户限额而引起 表空间可能有足够的空余空间 但用户可能将其在该表空间中所分配的部分用完了 在这种情况下 Oracle 自动清除该表空间中属于该用户的对象

  此外 有几种方法可以手动控制回收站 如果在删除名为 TEST 的特定表之后需要从回收站中清除它 可以执行

  

  

  PURGE TABLE TEST;

  或者使用其回收站中的名称

  

  

  PURGE TABLE BIN$ LhcpndanfgMAAAAAANPw==$ ;

  此命令将从回收站中删除表 TEST 及所有相关对象 如索引 约束等 从而节省了空间 但是 如果要从回收站中永久删除索引 则可以使用以下命令来完成工作

  

  

  purge index in_test _ ;

  此命令将仅仅删除索引 而将表的拷贝留在回收站中 有时在更高级别上进行清除可能会有用 例如 您可能希望清除表空间 USERS 的回收站中的所有对象 可以执行

  

  

  PURGE TABLESPACE USERS;

    您也许希望只为该表空间中特定用户清空回收站 在数据仓库类型的环境中 用户创建和删除许多临时表 此时这种方法可能会有用 您可以更改上述命令 限定只清除特定的用户

  

  

  PURGE TABLESPACE USERS USER SCOTT;

  诸如 SCOTT 等用户可以使用以下命令来清空自己的回收站

  

  

  PURGE RECYCLEBIN;

  DBA 可以使用以下命令清除任何表空间中的所有对象

  

  

  PURGE DBA_RECYCLEBIN;

  可以看到 可以通过多种不同方法来管理回收站 以满足特定的需要

  表版本和闪回功能

  用户可能会经常多次创建和删除同一个表 如

  

  

  CREATE TABLE TEST (COL NUMBER);INSERT INTO TEST VALUES ( );mit;DROP TABLE TEST;CREATE TABLE TEST (COL NUMBER);INSERT INTO TEST VALUES ( );mit;DROP TABLE TEST;CREATE TABLE TEST (COL NUMBER);INSERT INTO TEST VALUES ( );mit;DROP TABLE TEST;

  此时 如果您要对表 TEST 执行闪回操作 那么列 COL 的值应该是什么?常规想法可能认为从回收站取回表的之一个版本 列 COL 的值是 实际上 取回的是表的第三个版本 而不是之一个 因此列 COL 的值为 而不是

  此时您还可以取回被删除表的其他版本 但是 表 TEST 的存在不允许出现这种情况 您有两种选择

  使用重命名选项

  

  

  FLASHBACK TABLE TEST TO BEFORE DROP RENAME TO TEST ;FLASHBACK TABLE TEST TO BEFORE DROP RENAME TO TEST ;

  这些语句将表的之一个版本恢复到 TEST 将第二个版本恢复到 TEST TEST 和 TEST 中的列 COL 的值将分别是 和 或者 使用表的特定回收站名称进行恢复 为此 首先要识别表的回收站名称 然后执行

  

  

  FLASHBACK TABLE BIN$ LhcpnoanfgMAAAAAANPw==$ TO BEFORE DROP RENAME TO TEST ;FLASHBACK TABLE BIN$ LhcpnqanfgMAAAAAANPw==$ TO BEFORE DROP RENAME TO TEST ;

  这些语句将恢复被删除表的两个版本

  警告

  取消删除特性使表恢复其原始名称 但是索引和触发器等相关对象并没有恢复原始名称 它们仍然使用回收站的名称 在表上定义的源(如视图和过程)没有重新编译 仍然保持无效状态 必须手动得到这些原有名称并应用到闪回表

  信息保留在名为 USER_RECYCLEBIN 的视图中 在对表进行闪回操作前 请使用以下查询来检索原有名称

  

  

  SELECT OBJECT_NAME ORIGINAL_NAME TYPEFROM USER_RECYCLEBINWHERE BASE_OBJECT = (SELECT BASE_OBJECT FROM USER_RECYCLEBINWHERE ORIGINAL_NAME = RECYCLETEST )AND ORIGINAL_NAME != RECYCLETEST ;

  OBJECT_NAMEORIGINAL_N TYPE BIN$ LhcpnianfgMAAAAAANPw==$ IN_RT_   INDEXBIN$ LhcpnganfgMAAAAAANPw==$ TR_RT TRIGGER

  在表进行闪回操作后 表 RECYCLETEST 上的索引和触发器将按照 OBJECT_NAME 列中所示进行命名 根据以上查询 可以使用原始名称重新命名对象 如下所示

  

  

  ALTER INDEX BIN$ LhcpnianfgMAAAAAANPw==$ RENAME TO IN_RT_ ;ALTER TRIGGER BIN$ LhcpnganfgMAAAAAANPw==$ RENAME TO TR_RT;

lishixinzhi/Article/program/Oracle/202311/17794

如何查看数据库开启闪回的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于如何查看数据库开启闪回,快速掌握数据库闪回查看技巧,Oracle闪回默认是关闭的,为什么在数据库打开后不能启用闪回功能?,Oracle10g数据库中闪回表特性剖析的信息别忘了在本站进行查找喔。


数据运维技术 » 快速掌握数据库闪回查看技巧 (如何查看数据库开启闪回)