数据库闪回是一种数据库恢复技术,它可以将数据库快速还原到过去的某个时间点,以便数据丢失时快速恢复数据。闪回技术可以快速查看数据库中的数据变化情况,以帮助数据库管理员进行故障排查和安全审计。本文将介绍如何快速掌握数据库闪回的查看技巧。
创新互联专注于企业成都全网营销推广、网站重做改版、福山网站定制设计、自适应品牌网站建设、H5建站、成都做商城网站、集团公司官网建设、外贸网站建设、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为福山等各大城市提供网站开发制作服务。
一、准备工作
在进行数据库闪回查看之前,需要先进行准备工作。必须确定数据库版本,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. 数据库闪回操作不适用于数据损坏的情况,此时需要使用其他的恢复方法。
通过本文的介绍,我们可以了解到如何快速掌握数据库闪回的查看技巧。使用闪回技术可以帮助管理员快速查找数据变更记录,从而进行必要的故障排查和安全审计。对于数据库管理员来说,掌握闪回技术是非常重要的一项技能,也是数据库实践中不可或缺的一环。
相关问题拓展阅读:
首先关岩嫌岩闭数据库: shutdown immediate;
在粗御开启到mount状态:startup mount;
修者仔改闪回功能:alter database flashback on;
开启数据库:alter datebase open;
要在oracle数据库处于侍滑mount状态的时老改腊候才能启用或者关闭archivelog功能。
先
startup monut;
再
alter database archivelog;
然后歼培
alter database open;
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数据库中闪回表特性剖析的信息别忘了在本站进行查找喔。
香港服务器选创新互联,2H2G首月10元开通。
创新互联(www.cdcxhl.com)互联网服务提供商,拥有超过10年的服务器租用、服务器托管、云服务器、虚拟主机、网站系统开发经验。专业提供云主机、虚拟主机、域名注册、VPS主机、云服务器、香港云服务器、免备案服务器等。
当前文章:快速掌握数据库闪回查看技巧(如何查看数据库开启闪回)
网站路径:http://www.shufengxianlan.com/qtweb/news13/124363.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联