成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Oracle undo探索

IT那活兒 / 3496人閱讀
Oracle undo探索

點擊上方“IT那活兒”,關注后了解更多內(nèi)容,不管IT什么活兒,干就完了?。?!




概  述

1


undo段又叫rollback段,undo的前身就是rollback,查詢undo段。

大家都知道的,修改數(shù)據(jù)后,沒有提交的數(shù)據(jù)寫到硬盤上,修改前的數(shù)據(jù)放在undo segment上。雖然未提交的數(shù)據(jù)已經(jīng)寫入硬盤,但另外的會話查詢時是從undo segment上讀取數(shù)據(jù),在事務沒有結束前,undo里的數(shù)據(jù)不會清除。
若事務太大導致undo空間不夠,此時這個事務就會失敗。



實驗前準備

2


查出表內(nèi)容:


SQL> select * from t2;
ID NA
---------- --
1 A
2 a
3 b
4 c
修改一行記錄:
SQL> update t2 set NAME=ab where id=4;
1 row updated.





從邏輯層面獲取塊數(shù)據(jù)

3


該表的行數(shù)據(jù)所在的邏輯文件編號和塊編號:


SQL> select dbms_rowid.rowid_relative_fno(rowid) fno,dbms_rowid.rowid_block_number(rowid) bn1 from t2;
FNO BN1
---------- ----------
41    1519940
41    1519940
41    1519940
41    1519940
sys用戶操作,查詢dump文件路徑,是用戶進程,所以看user_dump_dest:
SQL> show parameter dump
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
background_core_dump string      partial
background_dump_dest string      /u01/app/oracle/diag/rdbms/ocs
tstdb/ocststdb/trace
core_dump_dest string      /u01/app/oracle/diag/rdbms/ocs
tstdb/ocststdb/cdump
max_dump_file_size string      unlimited
shadow_core_dump string      partial
user_dump_dest string      /u01/app/oracle/diag/rdbms/ocs
tstdb/ocststdb/trace
生成邏輯編號是41,塊編號是1519940的dump文件:
SQL> alter system dump datafile 41 block 1519940;
System altered.
查詢該session產(chǎn)生的dump文件,或者在沒有其他session的前提下,直接看最新的dump文件:
SQL> select distinct sid from v$mystat;
SID
----------
581
SQL> select paddr from v$session where sid=581;
PADDR
----------------
0000000253FCC010
SQL> select spid from v$process where addr=0000000253FCC010;
SPID
------------------------
8212
找到dump文件,下載到本地:
[oracle@ocsdbtest trace]$ pwd
/u01/app/oracle/diag/rdbms/ocststdb/ocststdb/trace
[oracle@ocsdbtest trace]$ ls *8212.trc
ocststdb_ora_8212.trc
用UE打開,主要最后面的:
.................
Start dump data blocks tsn: 42 file#:41 minblk 1519940 maxblk 1519940
.................
Itl Xid Uba Flag Lck Scn/Fsc
0x01 0x0003.017.002c083b 0x00c004f8.e3f0.06  C--- 0  scn 0x0e73.5c418bf9
0x02 0x0009.010.002c7c61 0x00c0032e.e670.23  ---- 1  fsc 0x0000.00000000
bdba: 0x0a573144
data_block_dump,data header at 0x7f0ea1953a64
===============
tsiz: 0x1f98
hsiz: 0x1a
pbl: 0x7f0ea1953a64
76543210
flag=--------
ntab=1
nrow=4
frre=-1
fsbo=0x1a
fseo=0x1f6f
avsp=0x1f5a
tosp=0x1f5a
0xe:pti[0] nrow=4  offs=0
0x12:pri[0] offs=0x1f90
0x14:pri[1] offs=0x1f88
0x16:pri[2] offs=0x1f80
0x18:pri[3] offs=0x1f6f
block_row_dump:
tab 0, row 0, @0x1f90
tl: 8 fb: --H-FL-- lb: 0x0 cc: 2
col  0: [ 2] c1 02
col  1: [ 1] 41
tab 0, row 1, @0x1f88
tl: 8 fb: --H-FL-- lb: 0x0 cc: 2
col  0: [ 2] c1 03
col  1: [ 1] 61
tab 0, row 2, @0x1f80
tl: 8 fb: --H-FL-- lb: 0x0 cc: 2
col  0: [ 2] c1 04
col  1: [ 1] 62
tab 0, row 3, @0x1f6f
tl: 9 fb: --H-FL-- lb: 0x2 cc: 2
col  0: [ 2] c1 05
col  1: [ 2] 61 62
end_of_block_dump
End dump data blocks tsn: 42 file#: 41 minblk 1519940 maxblk 1519940





從物理磁盤層面獲取塊數(shù)據(jù)

4


再次dump絕對文件的內(nèi)容:


SQL> alter system dump datafile /oradata/ocststdb/TSSXCPMIS01.dbf block 1519940;
System altered.
由于在同一個session下dump的,trc文件也是一樣的,再次下載,UE打開:
...............
Start dump data block from file /oradata/ocststdb/TSSXCPMIS01.dbf minblk 1519940 maxblk 1519940
.............
Itl Xid Uba Flag Lck Scn/Fsc
0x01   0x0003.017.002c083b 0x00c00b68.6795.07  C--- 0 scn 0x0e73.5c418bf9
0x02   0x0009.010.002c7c61 0x00c00b68.6795.0b ---- 1 fsc 0x0000.00000000
bdba: 0x0a573144
data_block_dump,data header at 0x7f0ea1953a64
===============
tsiz: 0x1f98
hsiz: 0x1a
pbl: 0x7f0ea1953a64
76543210
flag=--------
ntab=1
nrow=4
frre=-1
fsbo=0x1a
fseo=0x1f6f
avsp=0x1f5a
tosp=0x1f5a
0xe:pti[0] nrow=4  offs=0
0x12:pri[0] offs=0x1f90
0x14:pri[1] offs=0x1f88
0x16:pri[2] offs=0x1f80
0x18:pri[3] offs=0x1f6f
block_row_dump:
tab 0, row 0, @0x1f90
tl: 8 fb: --H-FL-- lb: 0x0 cc: 2
col  0: [ 2] c1 02
col  1: [ 1] 41
tab 0, row 1, @0x1f88
tl: 8 fb: --H-FL-- lb: 0x0 cc: 2
col  0: [ 2] c1 03
col  1: [ 1] 61
tab 0, row 2, @0x1f80
tl: 8 fb: --H-FL-- lb: 0x0 cc: 2
col  0: [ 2] c1 04
col  1: [ 1] 62
tab 0, row 3, @0x1f6f
tl: 9 fb: --H-FL-- lb: 0x2 cc: 2
col  0: [ 2] c1 05
col  1: [ 2] 61 62
end_of_block_dump
End dump data block from file /oradata/ocststdb/TSSXCPMIS01.dbf minblk 1519940 maxblk 1519940
這一行意思開始dump文件“/oradata/ocststdb/TSSXCPMIS01.dbf”,塊“1519940”:
Start dump data block from file /oradata/ocststdb/TSSXCPMIS01.dbf minblk 1519940 maxblk 1519940
有4行數(shù)據(jù):
nrow=4
改行數(shù)據(jù)有鎖,0x2,沒鎖的是0x0:
tl: 9 fb: --H-FL-- lb: 0x2 cc: 2
最后一行內(nèi)容是2列:
col  0: [ 2] c1 05
col  1: [ 2] 61 62





從undo段獲取塊數(shù)據(jù)

5


截取地址(Uba:0x00c00b68.6795.07),0x和第一個“.”之間內(nèi)容,00c00b68,這是個16進制的地址,通過這個地址獲取文件編號和塊編號。

先轉換成10進制數(shù):
SQL> select to_number(00c00b68,xxxxxxxxxx) from dual;
TO_NUMBER(00C00B68,XXXXXXXXXX)
----------------------------------
12585832
獲取文件編號:
SQL> select dbms_utility.data_block_address_file(12585832) from dual;
DBMS_UTILITY.DATA_BLOCK_ADDRESS_FILE(12585832)
----------------------------------------------
3
獲取塊編號:
SQL> select dbms_utility.data_block_address_block(12585832) from dual;
DBMS_UTILITY.DATA_BLOCK_ADDRESS_BLOCK(12585832)
-----------------------------------------------
2920
查看當前undo使用的那個表空間:
SQL> show parameter undo_tablespace
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
undo_tablespace string UNDOTBS1
查詢UNDOTBS的文件編號:
SQL> select file_id from dba_data_files where tablespace_name=UNDOTBS1;
FILE_ID
----------
3
由此確認通過Uba獲取的文件編號的正確。
將這個文件dump出來:
SQL> alter system dump datafile 3 block 2920;
System altered.
地址(Uba:0x00c00b68.6795.07)最后一位是07地址,打開dump文件找到地址為07的,看到它的值是63,即“c”,也就是原數(shù)據(jù)存放到undo表空間去了:
*-----------------------------
* Rec #0x7 slt: 0x1a objn: 176942(0x0002b32e) objd: 176942  tblspc: 42(0x0000002a)
* Layer: 11 (Row) opc: 1   rci 0x00
Undo type: Regular undo    Begin trans Last buffer split:  No
Temp Object:  No
Tablespace Undo: No
rdba: 0x00000000Ext idx: 0
flg2: 0
*-----------------------------
uba: 0x00c00b68.6795.06 ctl max scn: 0x0e73.5c4ac77d prv tx scn: 0x0e73.5c4ac783
txn start scn: scn: 0x0e73.5c4a9dce logon user: 130
prev brb: 12585831 prev bcl: 0
KDO undo record:
KTB Redo
op: 0x03 ver: 0x01
compat bit: 4 (post-11) padding: 1
op: Z
KDO Op code: URP row dependencies Disabled
xtype: XA flags: 0x00000000 bdba: 0x0a573144 hdba: 0x0a573142
itli: 2  ispac: 0  maxfr: 4858
tabn: 0 slot: 3(0x3) flag: 0x2c lock: 0 ckix: 0
ncol: 2 nnew: 1 size: -1
col  1: [ 1] 63
查出“a”和“b”的ASSIC值:
SQL> select ascii(a) from dual;
ASCII(A)
----------
97
SQL> select ascii(b) from dual;
ASCII(B)
----------
98
將97和98轉換成16進制,則是61和62,正式最后一行的內(nèi)容:
SQL> select to_char(97,XX) from dual;
TO_
---
61
SQL> select to_char(98,XX) from dual;
TO_
---
62





各層面獲取的數(shù)據(jù)對比

6


可以看到第一個dump文件,邏輯文件編號出來的文件,和第二個dump文件,絕對文件編號出來的文件,在最后一行的內(nèi)容都是一致的:


col  1: [ 2] 61 62
即從內(nèi)存中讀取出來的內(nèi)容和從硬盤讀取出來的內(nèi)容是一樣的,未commit就已經(jīng)寫到磁盤上了。
沒提交的數(shù)據(jù)是有標記的,是有鎖的,其他session是查不到的。其他session查詢該數(shù)據(jù),讀到這個塊時發(fā)現(xiàn)有鎖,“tl: 9 fb: --H-FL-- lb: 0x2  cc: 2”,可以看到Lck是“1”,表示有1條數(shù)據(jù)鎖定。




總  結

7


通過dump數(shù)據(jù)得到驗證,表的邏輯數(shù)據(jù)和磁盤數(shù)據(jù)都保存的是新數(shù)據(jù),undo段里則保存原始數(shù)據(jù)。



本文作者:胡 偉

本文來源:IT那活兒(上海新炬王翦團隊)

文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://systransis.cn/yun/129604.html

相關文章

發(fā)表評論

0條評論

IT那活兒

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<