av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術(shù)文章
文章詳情頁

Oracle的回滾段存儲內(nèi)容分析

瀏覽:112日期:2023-11-29 14:26:36

事務(wù)在執(zhí)行DML操作時,會首先將相關(guān)的數(shù)據(jù)塊寫入數(shù)據(jù)緩沖區(qū)中,數(shù)據(jù)緩沖區(qū)中存儲的是DML操作相關(guān)的完整數(shù)據(jù)塊,比如我們對表中的某一個記錄執(zhí)行update操作,oracle會將記錄所在的數(shù)據(jù)塊讀入數(shù)據(jù)緩沖區(qū)中。

在執(zhí)行update操作之后,oracle后臺進(jìn)程會首先將修改前的內(nèi)容(包括數(shù)據(jù)塊中其他記錄內(nèi)容)以及scn,塊信息等寫入回滾段中,但這里寫的時候不僅僅只是簡單的塊復(fù)制,而是將原來的數(shù)據(jù)塊順序?qū)懭牖貪L段的數(shù)據(jù)塊。測試表明,在源表數(shù)據(jù)塊占用空間較少的情況下(比如設(shè)置pctfree為99),對源表兩個數(shù)據(jù)塊中記錄的修改只占用一個回滾段中的數(shù)據(jù)塊(因為這時回滾段的數(shù)據(jù)塊pctfree值是默認(rèn)的,相對較小,一個回滾塊可以存儲更多的源數(shù)據(jù)塊)。但如果設(shè)置源表占用空間較大,比如設(shè)置默認(rèn)或者設(shè)pctfree為1,則對源表的兩個數(shù)據(jù)塊內(nèi)容修改時,會占用回滾段中的兩個數(shù)據(jù)塊。

同時會將修改記錄的前后內(nèi)容都寫入重做日志文件中(這里只寫入修改前后的該記錄的信息,數(shù)據(jù)塊中的其他記錄將不會寫入重做日志)。

一旦用戶對該操作執(zhí)行了commit或rollback操作,回滾段內(nèi)容會理解清空。

現(xiàn)在我們來作個測試驗證上面的說法。

1, 創(chuàng)建一個用戶表Trollsegment,并插入數(shù)據(jù)1000條記錄到表中

droptabletrollsegment;createtabletrollsegment(

FID integer,

Fname varchar2(40),

Fothers varchar2(40)

) tablespaceodsdpctfree98

insertintotrollsegmentselectrownum, rpad('name',20,rownum),rpad('other',20,rownum)fromdba_objectswhererownum<1000

commit

2, 轉(zhuǎn)儲表中FID=10的數(shù)據(jù)塊內(nèi)容

selectdbms_rowid.rowid_block_number(rowid),count(*) fromtrollsegment groupbydbms_rowid.rowid_block_number(rowid)selectdbms_rowid.rowid_block_number(rowid),dbms_rowid.rowid_relative_fno(rowid),fid fromtrollsegment wherefid = 10

1 7437 14 10

SQL> alter system dump datafile 14 block 7437;

System altered

*** 2009-02-07 10:28:48.629

Start dump data blocks tsn: 11 file#: 14 minblk 7437 maxblk 7437

buffer tsn: 11 rdba: 0x03801d0d (14/7437)

scn: 0x0001.8569780b seq: 0x01 flg: 0x02 tail: 0x780b0601

frmt: 0x02 chkval: 0x0000 type: 0x06=trans data

Block header dump: 0x03801d0d

Object id on Block? Y

seg/obj: 0x167cc csc: 0x01.856977e6 itc: 2 flg: E typ: 1 - DATA

brn: 0 bdba: 0x3801d09 ver: 0x01

inc: 0 exflg: 0

Itl Xid Uba Flag Lck Scn/Fsc

0x01 0x0012.018.0000034d 0x0e000c3e.0054.48 --U- 3 fsc 0x0000.8569780b

0x02 0x0000.000.00000000 0x00000000.0000.00 ---- 0 fsc 0x0000.00000000

data_block_dump,data header at 0x80000001001a3864

===============

tsiz: 0x1f98

hsiz: 0x18

pbl: 0x80000001001a3864

bdba: 0x03801d0d

76543210

flag=--------

ntab=1

nrow=3

frre=-1

fsbo=0x18

fseo=0x1f08

avsp=0x1ef0

tosp=0x1ef0

0xe:pti[0] nrow=3 offs=0

0x12:pri[0] offs=0x1f08

0x14:pri[1] offs=0x1f38

0x16:pri[2] offs=0x1f68

block_row_dump:

tab 0, row 0, @0x1f08

tl: 48 fb: --H-FL-- lb: 0x1 cc: 3

col 0: [ 2] c1 0b

col 1: [20] 6e 61 6d 65 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30

col 2: [20] 6f 74 68 65 72 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31

tab 0, row 1, @0x1f38

tl: 48 fb: --H-FL-- lb: 0x1 cc: 3

col 0: [ 2] c1 0c

col 1: [20] 6e 61 6d 65 31 31 31 31 31 31 31 31 31 31 31 31 31 31 31 31

col 2: [20] 6f 74 68 65 72 31 31 31 31 31 31 31 31 31 31 31 31 31 31 31

tab 0, row 2, @0x1f68

3, 對FID=10的記錄做更新,但不提交

updatetrollsegment setfname = replace(fname,'name','eman')wherefid = 10orfid = 20

4, 查看當(dāng)前事務(wù)所占回滾段和起始回滾塊,并導(dǎo)出當(dāng)前回滾塊的內(nèi)容與轉(zhuǎn)儲出去的表內(nèi)容進(jìn)行比較。

查看當(dāng)前活動事務(wù)占用的回滾段信息

SELECTs.username,t.xidusn,t.ubafil,t.ubablk,t.used_ublk FROMv$session s,v$transaction t WHEREs.saddr=t.ses_addr;

1 SYS19 56 2269 2

修改的內(nèi)容在兩個數(shù)據(jù)塊中,但回滾段只占用了一個數(shù)據(jù)塊。

測試2:設(shè)置pctfree較小的情況

droptabletrollsegment;createtabletrollsegment(

FID integer,

Fname varchar2(400),

Fothers varchar2(400)

) tablespaceodsdpctfree1

insertintotrollsegmentselectrownum, rpad('name',400,rownum),rpad('other',400,rownum)fromdba_objectswhererownum<1000

commit

selectdbms_rowid.rowid_block_number(rowid),count(*) fromtrollsegment groupbydbms_rowid.rowid_block_number(rowid)selectdbms_rowid.rowid_block_number(rowid),dbms_rowid.rowid_relative_fno(rowid),fid fromtrollsegment wherefid = 10

updatetrollsegment setfname = replace(fname,'name','eman')wherefid = 10orfid = 30

SELECTs.username,t.xidusn,t.ubafil,t.ubablk,t.used_ublk FROMv$session s,v$transaction t WHEREs.saddr=t.ses_addr;

轉(zhuǎn)儲回滾段內(nèi)容

SELECTb.name,a.xidusn, xidslot, xidsqn

FROMv$transaction a, v$rollname b

wherea.XIDUSN = b.usn;

1 _SYSSMU16$16 26 799

SQL> alter system dump undo block '_SYSSMU16$'

2 xid 16 26 799;

System altered

*** 2009-02-07 11:12:10.687

********************************************************************************

Undo Segment: _SYSSMU16$ (16)

xid: 0x0010.01a.0000031f

Low Blk : (0, 0)

High Blk : (3, 127)

Object Id : ALL

Layer : ALL

Opcode : ALL

Level : 2

********************************************************************************

UNDO BLK: Extent: 2 Block: 78 dba (file#, block#): 56,0x00000857

xid: 0x0010.01a.0000031f seq: 0x52 cnt: 0x4f irb: 0x4f icl: 0x0 flg: 0x0000

Rec Offset Rec Offset Rec Offset Rec Offset Rec Offset

---------------------------------------------------------------------------

0x01 0x1fac 0x02 0x1f54 0x03 0x1efc 0x04 0x1ec4 0x05 0x1e6c

0x06 0x1e14 0x07 0x1ddc 0x08 0x1d84 0x09 0x1d2c 0x0a 0x1cf4

0x0b 0x1c9c 0x0c 0x1c44 0x0d 0x1c0c 0x0e 0x1bb4 0x0f 0x1b5c

0x10 0x1b24 0x11 0x1acc 0x12 0x1a74 0x13 0x1a3c 0x14 0x1a04

0x15 0x19ac 0x16 0x1954 0x17 0x191c 0x18 0x18c4 0x19 0x186c

0x1a 0x1834 0x1b 0x17dc 0x1c 0x1784 0x1d 0x174c 0x1e 0x16f4

0x1f 0x169c 0x20 0x1664 0x21 0x160c 0x22 0x15b4 0x23 0x157c

0x24 0x1524 0x25 0x14cc 0x26 0x1494 0x27 0x143c 0x28 0x13e4

0x29 0x13ac 0x2a 0x1354 0x2b 0x12fc 0x2c 0x12c4 0x2d 0x126c

0x2e 0x1214 0x2f 0x11dc 0x30 0x1184 0x31 0x112c 0x32 0x10f4

0x33 0x109c 0x34 0x1044 0x35 0x100c 0x36 0x0fb4 0x37 0x0f5c

0x38 0x0f24 0x39 0x0ecc 0x3a 0x0e74 0x3b 0x0e3c 0x3c 0x0de4

0x3d 0x0d8c 0x3e 0x0d54 0x3f 0x0cfc 0x40 0x0ca4 0x41 0x0c6c

0x42 0x0c14 0x43 0x0bbc 0x44 0x0b84 0x45 0x0b2c 0x46 0x0ad4

0x47 0x0a9c 0x48 0x0a44 0x49 0x09ec 0x4a 0x09b4 0x4b 0x095c

0x4c 0x0904 0x4d 0x08cc 0x4e 0x06b4 0x4f 0x04b4

*-----------------------------

* Rec #0x4f slt: 0x1a objn: 92112(0x000167d0) objd: 92112 tblspc: 11(0x0000000b)

* Layer: 11 (Row) opc: 1 rci 0x4e

Undo type: Regular undo Last buffer split: No

Temp Object: No

Tablespace Undo: No

rdba: 0x00000000

*-----------------------------

KDO undo record:

KTB Redo

op: 0x04 ver: 0x01

op: L itl: xid: 0x0013.02e.00000354 uba: 0x0e0008de.0052.31

flg: C--- lkc: 0 scn: 0x0001.85698ef5

KDO Op code: URP row dependencies Disabled

xtype: XA bdba: 0x03801d10 hdba: 0x03801d0b

itli: 1 ispac: 0 maxfr: 4858

tabn: 0 slot: 0(0x0) flag: 0x2c lock: 0 ckix: 88

ncol: 3 nnew: 1 size: 0

col 1: [400]

65 6d 61 6e 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31

30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30

31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31

30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30

31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31

30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30

31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31

30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30

31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31

30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30

31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31

30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30

31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31

30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30

31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31

30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30 31 30

*-----------------------------

* Rec #0x4e slt: 0x1a objn: 92112(0x000167d0) objd: 92112 tblspc: 11(0x0000000b)

* 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: 0x0e000857.0052.4d ctl max scn: 0x0001.85698f76 prv tx scn: 0x0001.85698f79

KDO undo record:

KTB Redo

op: 0x04 ver: 0x01

op: L itl: xid: 0x0013.02e.00000354 uba: 0x0e0008de.0052.35

flg: C--- lkc: 0 scn: 0x0001.85698ef5

KDO Op code: URP row dependencies Disabled

xtype: XA bdba: 0x03801d0d hdba: 0x03801d0b

itli: 1 ispac: 0 maxfr: 4858

tabn: 0 slot: 2(0x2) flag: 0x2c lock: 0 ckix: 88

ncol: 3 nnew: 1 size: 0

col 1: [400]

65 6d 61 6e 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33

30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30

33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33

30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30

33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33

30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30

33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33

30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30

33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33

30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30

33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33

30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30

33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33

30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30

33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33

30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30 33 30

+++++++++++ Next block not in extent map - rollback segment has been shrunk.

+ WARNING + Block dba (file#, block#): 0,0x00000000

標(biāo)簽: Oracle 數(shù)據(jù)庫
相關(guān)文章:
主站蜘蛛池模板: 亚洲欧美日韩一区二区 | 99在线视频免费观看 | 欧美一区二区三区免费 | 天天色影院 | 亚洲欧美第一页 | 国产精品二区一区二区aⅴ污介绍 | 欧美亚洲激情 | 秋霞午夜鲁丝一区二区老狼 | 日韩av中文字幕在线播放 | 亚洲一区二区三区在线视频 | 不卡av在线播放 | 日韩av一区二区三区四区 | 欧美日韩一本 | 九九热这里 | 中文字幕在线一区二区三区 | 日韩成人中文字幕 | 欧美日韩亚洲一区二区 | 五月婷婷综合激情 | 黄色一级免费看 | 亚洲综合影院 | 日韩av在线影院 | 在线观看黄色片 | 久久久久久久久久一区二区三区 | 国产精品一区二区三区免费 | 我想看毛片 | 久热伊人 | 国产一区不卡 | 午夜免费剧场 | 日韩专区在线观看 | 久久久久久久久国产精品 | 国产高清在线视频 | 免费的黄色小视频 | 香蕉福利视频 | 日本国产视频 | 精品亚洲一区二区三区 | 久久精品视频一区 | 一区二区精品视频 | 另类在线视频 | 国产美女精品 | 91免费网站入口 | 欧美日韩国产三级 |