itl在被覆蓋之前被儲存了下來1!
之後構造consistent read而使用。[@more@]
SQL> create table t(id int) initrans 1;
表已建立。
SQL> insert into t values(1);
已建立 1 行。
SQL> select id,dbms_rowid.rowid_relative_fno(rowid) fno,dbms_rowid.rowid_block_n
umber(rowid) bno from t;
ID FNO BNO
---------- ---------- ----------
1 1 32962
--===============================
session 2:(session 2的這個操作沒有任何實際意義,
目的就是佔用一個itl)
SQL> insert into t values(2);
已建立 1 行。
--===============================
session 1:
SQL> alter system dump datafile 1 block 32962;
系統已更改。
--========================
Itl Xid Uba Flag Lck Scn/Fsc
0x01 0x000c.004.0000099e 0x01c0001d.198e.21 ---- 1 fsc 0x0000.00000000
0x02 0x000f.024.00000997 0x01c000e7.18ef.3c ---- 1 fsc 0x0000.00000000
--========================
SQL> commit;
提交完成。
SQL> alter system dump datafile 1 block 32962;
系統已更改。
--==========================
Itl Xid Uba Flag Lck Scn/Fsc
0x01 0x000c.004.0000099e 0x01c0001d.198e.21 --U- 1 fsc 0x0000.018ed530
0x02 0x000f.024.00000997 0x01c000e7.18ef.3c ---- 1 fsc 0x0000.00000000
--===========================
--這裡有個疑問:事務提交之後為什麼第一個itl中的flag標記是U(第三位)而不是C(第一位)?
SQL> insert into t select object_id from dba_objects;
已建立11315行。
SQL> select xidusn,xidslot,ubafil,ubarec,ubablk,start_ubablk,start_ubarec from v
$transaction;
XIDUSN XIDSLOT UBAFIL UBAREC UBABLK START_UBABLK START_UBAREC
---------- ---------- ---------- ---------- ---------- ------------ ------------
12 1 7 19 17 29 34
15 36 7 60 231 231 60
SQL> alter system dump datafile 7 block 17;
系統已更改。
--從下面的dump資訊中Rec #0x13(10進位制的19,上面查出來的ubarec)
沒有發現被事務(insert into t select object_id from dba_objects)
所覆蓋的itl。
--=================================
* Rec #0x13 slt: 0x01 objn: 11946(0x00002eaa) objd: 11946 tblspc: 0(0x00000000)
* Layer: 11 (Row) opc: 1 rci 0x12
Undo type: Regular undo Last buffer split: No
Temp Object: No
Tablespace Undo: No
rdba: 0x00000000
*-----------------------------
KDO undo record:
KTB Redo
op: 0x02 ver: 0x01
op: C uba: 0x01c00011.198f.12
KDO Op code: QMD row dependencies Disabled
xtype: XA flags: 0x00000000 bdba: 0x00408263 hdba: 0x004080c1
itli: 1 ispac: 0 maxfr: 4863
tabn: 0 lock: 0 nrow: 95
--=================================
接下來再來dump這個事務使用的undo chain的start_ubablk:
SQL> alter system dump datafile 7 block 29;
系統已更改。
--從下面的dump資訊中Rec #0x22(10進位制的34,上面查出來的start_ubarec)
我們發現了被事務(insert into t select object_id from dba_objects)
所覆蓋的由事務(insert into t values(1);插入的第一條記錄)所使用的itl:
0x01 0x000c.004.0000099e 0x01c0001d.198e.21 ---- 1 fsc 0x0000.00000000
--==============================
* Rec #0x22 slt: 0x01 objn: 11946(0x00002eaa) objd: 11946 tblspc: 0(0x00000000)
* Layer: 11 (Row) opc: 1 rci 0x00
Undo type: Regular undo Begin trans Last buffer split: No
Temp Object: No
Tablespace Undo: No
rdba: 0x00000000
*-----------------------------
uba: 0x01c0001d.198e.21 ctl max scn: 0x0000.018ecec6 prv tx scn: 0x0000.018eced6
txn start scn: scn: 0x0000.018ed54c logon user: 0
prev brb: 29360155 prev bcl: 0
KDO undo record:
KTB Redo
op: 0x04 ver: 0x01
op: L itl: xid: 0x000c.004.0000099e uba: 0x01c0001d.198e.21
flg: C--- lkc: 0 scn: 0x0000.018ed530
KDO Op code: QMD row dependencies Disabled
xtype: XA flags: 0x00000000 bdba: 0x004080c2 hdba: 0x004080c1
itli: 1 ispac: 0 maxfr: 4863
tabn: 0 lock: 0 nrow: 255
--===============================
結論:itl在被覆蓋之前放在了事務的undo chain(單向連結串列的尾)的start_ubablk中以備
之後構造consistent read而使用。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/19602/viewspace-1019104/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- itl在被覆蓋之前被儲存了下來!
- 恢復被覆蓋的儲存過程 oracle儲存過程Oracle
- 避免resolv.conf設定被覆蓋
- 如何找回oracle中被覆蓋的包體程式Oracle
- logminer來恢復在表DDL之前被刪除的資料
- 在iPhone8到來之前盤點一下iPhone1到iPhone7iPhone
- 儲存篇(1)
- 物件儲存,未來儲存新潮流物件
- [z] 利用閃回恢復被覆蓋的Oracle PACKAGE包OraclePackage
- “井蓋吃人”的屢見不鮮,智慧井蓋來了!
- 杉巖物件儲存當底座,IPFS:這下穩了物件
- CTEX安裝必須注意 系統變數 path 被覆蓋變數
- 重灌Windows後LILO被覆蓋的解決辦法(轉)Windows
- Control File中備份資訊被覆蓋情況下的資料庫恢復案例資料庫
- 儲存一下
- Oracle儲存過程-1Oracle儲存過程
- 棧1: 順序儲存
- Control File中備份資訊被覆蓋情況下的資料庫恢復案例 (zt)資料庫
- 在博物館裡儲存遊戲歷史有多難?(下)遊戲
- 教你在Ubuntu系統下儲存螢幕亮度設定Ubuntu
- undo transaction slot被覆蓋引起ORA-01555的原理解析
- 雲儲存時代的到來
- SAP Sybase IQ按列儲存介紹 - 1 按列儲存
- 申訴被駁!蘋果被要求在 12 月 9 日之前接入外部支付連結蘋果
- 重名就會被覆蓋?那JavaScript中是如何實現過載的呢?JavaScript
- 檔案替換後怎麼恢復,恢復被覆蓋的檔案
- 儲存系列1-openfiler開源儲存管理平臺實踐
- istanbul 繞過 window 變數儲存覆蓋率資料變數
- 資料儲存(1):從資料儲存看人類文明-資料儲存器發展歷程
- 【Python3網路爬蟲開發實戰】5-資料儲存-1 檔案儲存-1 TXT文字儲存Python爬蟲
- 在儲存過程A中呼叫儲存過程B的結果儲存過程
- 上海HP 儲存培訓歸來
- 比爾·蓋茨:AI應該被用來改善教育和醫療AI
- JavaScript本地儲存(1):cookie在前端JavaScriptCookie前端
- vmware測試1 儲存劃分
- 儲存過程獲取表被引用的資訊儲存過程
- 解決 flutter module 中 .android 和 .ios 目錄不被覆蓋的問題FlutterAndroidiOS
- 在sqlplus互動環境下測試儲存過程SQL儲存過程