本文主要是介绍【云原生进阶之数据库技术】第二章-Oracle-原理-4.6.3.7-闪回事务查询技术,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
1 闪回事物查询
1.1 闪回事务查询概念介绍
闪回事务查询是通过数据字典视图flashback_transaction_query来查询历史事务相关元数据,并且可以通过该视图的undo_sql字段会给出相应的SQL从逻辑层面撤销事务。闪回事务查询实际上是闪回版本查询的一个扩充,通过它可以审计某个事务甚至 撤销 一个已经提交的事务。闪回事务查询有别于闪回查询的特点有以下3个:
- 不但需要利用undo数据,还需要事先启用最小补充日志。
- 返回的结果不是以前的“旧”数据,而是能够将当前数据修改为以前的样子的撤销SQL语句(Undo SQL)。
- 都在flashback_transaction_query表上查询,而不是在各个表上通过“as of”或“versions between”子句查询。
flashback_transaction_query包含对数据库执行的所有更改,包括DDL操作。由于undo表空间有限,因此flashback_transaction_query中只包含一部分事物。
SELECT t.*
FROM flashback_transaction_query t
WHERE t.logon_user = 'SYSTEM'; -- 你登录的用户
-- GRANT SELECT ANY TRANSACTION TO scott; -- 测试用户,若权限不足,需授权
-- 添加补充日志 (若没有 undo_sql 为空)
SELECT t.supplemental_log_data_min
这篇关于【云原生进阶之数据库技术】第二章-Oracle-原理-4.6.3.7-闪回事务查询技术的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!