通過閃回事務檢視資料dml的情況
如果通過閃回事務來得到對應的undo_sql,可能多個dml語句對應一個事務,所以我們需要得到的是一個完整的事務的資訊,裡面包括對應的Undo_sql,這樣才算得到比較完整的sql語句。
我在本地自己做了一個測試。
建立一個test表,然後插入一些記錄,然後嘗試修改一些資料。
SQL> DROP TABLE TEST;
Table dropped.
SQL> create table test (id number,name varchar2(29));
Table created.
SQL> insert into test values(1,'trx1');
1 row created.
SQL> insert into test values(2,'trx1');
1 row created.
SQL> commit;
Commit complete.
SQL> insert into test values(3,'trx2');
1 row created.
SQL> commit;
Commit complete.
SQL> update test set id=4,name='trx3' where name='trx1';
2 rows updated.
SQL> commit;
Commit complete.
SQL> set linesize 200
SQL> col VENDTIME format a22
SQL> col V_STARTTIME format a22
SQL> select versions_starttime v_starttime,versions_startscn v_startscn,versions_xid xid,versions_endtime vendtime,versions_endscn vendscn,versions_operation oper,id,name from test versions between scn minvalue and maxvalue;
V_STARTTIME V_STARTSCN XID VENDTIME VENDSCN O ID NAME
---------------------- ---------- ---------------- ---------------------- ---------- - ---------- -----------------------------
19-AUG-14 05.30.14 AM 7233099 0A000F0070040000 U 4 trx3
19-AUG-14 05.30.14 AM 7233099 0A000F0070040000 U 4 trx3
19-AUG-14 05.29.44 AM 7233087 08001B00FD060000 I 3 trx2
19-AUG-14 05.29.38 AM 7233084 0700100091040000 19-AUG-14 05.30.14 AM 7233099 I 2 trx1
19-AUG-14 05.29.38 AM 7233084 0700100091040000 19-AUG-14 05.30.14 AM 7233099 I 1 trx1
得到了如上的資訊之後,就開始使用閃回事務來查詢,結果沒有任何返回。
SQL> select operation,undo_sql from flashback_transaction_query where table_name='TEST' and table_owner='N1';
no rows selected
檢視Undo的空間情況,undo還很充足。
Current Instance
~~~~~~~~~~~~~~~~
DB Id DB Name Inst Num Instance
----------- ------------ -------- ------------
3645037571 TEST01 1 TEST01
Tablespace STA M A Init Total MB Free MB Used MB LrgstMB MaxExt %Fr A
------------ --- - - ---- ------------ ---------- ----------- -------- ------------ --- -
POOL_DATA OLN L S 64K 960 765 195 98 2147483645 80
SYSAUX OLN L S 64K 325 96 229 91 2147483645 30
SYSTEM OLN L S 64K 325 51 274 50 2147483645 16 *
TEMPTS1 OLN L U 1M 400 400 0 286 100
TEST_DATA1 OLN L S 64K 3 2 1 2 2147483645 67
UNDOTBS OLN L S 64K 935 903 32 672 2147483645 97
------------ ---------- -----------
sum 2,948 2,217 731
使用閃回事務需要賦予一定的許可權,賦一下許可權。
使用dba連線,賦予許可權
SQL> conn / as sysdba
Connected.
SQL> grant execute on dbms_flashback to n1;
Grant succeeded.
SQL> grant select any transaction to n1;
Grant succeeded.
再次查詢驗證,還是沒有資料。
SQL> select operation,undo_sql from flashback_transaction_query where table_name='TEST' and table_owner='N1';
no rows selected
直接用sys看看,倒底是怎麼回事,能看到Operation 顯示為“unknown"而且對應的table_owner也是空。
conn / as sysdba
SQL> col undo_sql format a30
SQL> select table_owner,operation,undo_sql from flashback_transaction_query where table_name='TEST'
2 /
TABLE_OWNER OPERATION UNDO_SQL
-------------------------------- -------------------------------- ------------------------------
UNKNOWN
UNKNOWN
UNKNOWN
UNKNOWN
原來,需要使用alter database命令,啟用對DML更改引用的列值和主鍵值的日誌記錄。
SQL> alter database add supplemental log data;
Database altered.
SQL> conn n1/n1
Connected.
啟用之後,不會立即生效,我們來清空資料,重新插入一些資料。
SQL> select table_owner,operation,undo_sql from flashback_transaction_query where table_name='TEST'
2 /
TABLE_OWNER OPERATION UNDO_SQL
-------------------------------- -------------------------------- ------------------------------
UNKNOWN
UNKNOWN
UNKNOWN
UNKNOWN
SQL> truncate table test;
Table truncated.
SQL> insert into test values(1,'trx1');
1 row created.
SQL> insert into test values(2,'trx1');
1 row created.
SQL> commit;
Commit complete.
再次查詢就能夠成功顯示了。
SQL> col undo_sql format a80
SQL> select table_owner,operation,undo_sql from flashback_transaction_query where table_name='TEST';
TABLE_OWNER OPERATION UNDO_SQL
-------------------------------- -------------------------------- --------------------------------------------------------------------------------
N1 INSERT delete from "N1"."TEST" where ROWID = 'AAAEmOAAJAAABRjAAB';
N1 INSERT delete from "N1"."TEST" where ROWID = 'AAAEmOAAJAAABRjAAA';
UNKNOWN
UNKNOWN
UNKNOWN
UNKNOWN
解決了這個問題,就可以使用閃回事務表來檢視undo_sql了,我們根據start_timestamp來排列,得到最新的資料變化情況。
先使用閃回查詢來看看。
SQL> select versions_starttime v_starttime,versions_startscn v_startscn,versions_xid xid,versions_endtime vendtime,versions_endscn vendscn,versions_operation oper,id,name from test versions between scn minvalue and maxvalue;
V_STARTTIME V_STARTSCN XID VENDTIME VENDSCN O ID NAME
---------------------- ---------- ---------------- ---------------------- ---------- - ---------- -----------------------------
19-AUG-14 05.36.08 AM 7247547 05001A00C2050000 I 2 trx1
19-AUG-14 05.36.08 AM 7247547 05001A00C2050000 I 1 trx1
然後通過閃回事務來關聯。
SQL> select table_owner,START_TIMESTAMP,operation,undo_sql from flashback_transaction_query where table_name='TEST' and table_owner='N1' and xid=hextoraw('05001A00C2050000');
TABLE_OWNER START_TIM OPERATION UNDO_SQL
-------------------------------- --------- -------------------------------- --------------------------------------------------------------------------------
N1 19-AUG-14 INSERT delete from "N1"."TEST" where ROWID = 'AAAEmOAAJAAABRjAAB';
N1 19-AUG-14 INSERT delete from "N1"."TEST" where ROWID = 'AAAEmOAAJAAABRjAAA';
在做undo之前,檢視錶裡現有的資料作比對。
SQL> select *from test;
ID NAME
---------- -----------------------------
1 trx1
2 trx1
SQL> delete from "N1"."TEST" where ROWID = 'AAAEmOAAJAAABRjAAB';
1 row deleted.
SQL> delete from "N1"."TEST" where ROWID = 'AAAEmOAAJAAABRjAAA';
1 row deleted.
SQL> select *from test;
no rows selected
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/23718752/viewspace-1254237/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 透過閃回事務檢視資料dml的情況
- 通過Nethogs檢視伺服器網路卡流量情況HOG伺服器
- 檢視PG資料庫的許可權情況資料庫
- 檢視過去的session鎖情況指令碼Session指令碼
- 檢視SQLServer的LCK資源等待情況SQLServer
- 閃回資料庫測試之二 :通過read only檢視閃回的結果資料庫
- 通過shell指令碼檢視資料庫表空間使用情況指令碼資料庫
- 使用shell指令碼檢視資料庫負載情況指令碼資料庫負載
- Linux 檢視程式情況Linux
- 檢視mount掛載情況
- 檢視ASM的Extent分佈情況ASM
- Oracle 通過undo塊檢視事務資訊Oracle
- 通過連線檢視資料庫相關資訊資料庫
- 使用shell指令碼檢視資料庫負載情況(第二篇)指令碼資料庫負載
- 巧用閃回資料庫來檢視歷史資料資料庫
- 通過 dbms_space.space_usage 檢視objects 的空間使用情況Object
- linux系統檢視系統資源分析效能情況Linux
- 通過作業系統的程式號檢視資料庫的session作業系統資料庫Session
- 通過資料庫鏈執行DML所需許可權資料庫
- 閃回版本查詢與閃回事務查詢
- 透過shell指令碼檢視資料庫表空間使用情況指令碼資料庫
- Android下檢視SO庫被依賴的情況Android
- OceanBase學習之路41|如何檢視資源池的分佈情況?
- 2.8.3 資料庫服務的資料字典檢視資料庫
- 【轉】Oracle:檢查被鎖資料在V$LOCK中的情況Oracle
- 【閃回特性之閃回事務查詢】Flashback Transaction Query
- 檢視mysql資料庫空間使用情況MySql資料庫
- 檢視資料庫中tablespace和datafile的使用情況。資料庫
- linux系統檢視網路連線情況Linux
- 如何快速檢視Linux系統重啟情況Linux
- Solaris10下檢視硬體RAID的磁碟情況AI
- check_postgres指令碼集檢查資料庫健康情況指令碼資料庫
- 聊聊閃回事務查詢Flashback Transaction Query
- 公司使用大資料的基本情況大資料
- Oracle 檢視可以DML操作的條件Oracle
- Oracle連線檢視DML操作的限制Oracle
- Linux如何通過命令檢視伺服器的記憶體條使用情況Linux伺服器記憶體
- 如何快速、及時、準確的閃回DML提交後的資料