oracle 使用闪回事务查询是 视图flashback_transaction_query中列operation为unknown 问题分析

很多时候在首次使用 视频flashback_transaction_query 执行闪回事务查询是,列operation全是unknown 而且undo_sql 也为空,

SQL> select operation,undo_sql from flashback_transaction_query
  2  where xid=hextoraw('09000E0065060000');

OPERATION            UNDO_SQL
-------------------- ----------------------------------------------------------------------
UNKNOWN
BEGIN

出现这种情况的原因可能有如下两种

一:因为撤销表空间有限,因此flashback_transaction_query视图中只包含一部分事务,对于任何所选事务不再显示在撤销表空间的DML,operation列的值是unknown。

二:使用闪回查询前,必须先启用重做日志流的其他日志记录。重做日志流数据时撤销表空间记录的信息的补充,闪回事务查询时既需要增强的重做信息,也需要撤销表空间的撤销信息。

首先,使用alter database命令,启用对DML更改引用的列值和主键值的日志记录:

SQL> alter database add supplemental log data;

数据库已更改。

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

数据库已更改。

注意,只有对alter database命令之后的DML操作在flashback_transaction_query中列operation和undo_sql才会有相应的值

SQL> update student set snum=200605,add_col='boy in ChengDu' where sid=24;

已更新 1 行。

SQL> commit;

提交完成。

SQL> select operation,undo_sql
  2  from flashback_transaction_query
  3  where xid=hextoraw('01001A00CE040000');

OPERATION            UNDO_SQL
-------------------- ----------------------------------------------------------------------
UPDATE               update "SU"."STUDENT" set "SNUM" = '21', "ADD_COL" = 'null' where ROWI
                     D = 'AAASU1AAEAAAAI9AAA';

BEGIN

 

另外补充一点,用户在执行闪回事务查询之前,必须为用户授予适当的DBMS_FLASHBACK包上的权限。

grant execute on dbms_flashback to user;

grant select any transaction to user;

你可能感兴趣的:(oracle,sql,数据库,null,database,query)