數(shù)據(jù)庫的版本是11.2.0.4
創(chuàng)新互聯(lián)建站堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站制作、成都網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的通州網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
歡迎大家加入ORACLE超級群:17115662 免費解決各種ORACLE問題,以后BLOG將遷移到http://www.htz.pw
1,數(shù)據(jù)庫版本
www.htz.pw > select * from v$version;
BANNER -------------------------------------------------------------------------------- Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - 64bit Production PL/SQL Release 11.2.0.3.0 - Production CORE 11.2.0.3.0 Production TNS for Linux: Version 11.2.0.3.0 - Production NLSRTL Version 11.2.0.3.0 - Production |
2,創(chuàng)建測試表
www.htz.pw > create table scott.htz tablespace users as select * from dba_objects where rownum<2;
Table created.
www.htz.pw > select rowid from scott.htz;
ROWID ------------------ AAASkGAAEAAABkzAAA
www.htz.pw > @rowid_to_info.sql Enter value for rowid: AAASkGAAEAAABkzAAA ROWID_TYPE: 1 OBJECT_NUMBER: 76038 RELATIVE_FNO: 4 BLOCK_NUMBER: 6451 ROW_NUMBER: 0
PL/SQL procedure successfully completed. |
3,模擬實驗
3.1 更新行記錄
www.htz.pw > conn scott/oracle Connected. www.htz.pw > select owner from htz;
OWNER ------------------------------ SYS
www.htz.pw > update htz set owner='HUANGTINGZHONG';
1 row updated. |
3.2 將BUFFER_CACHE中的塊刷到數(shù)據(jù)文件中
這里另外打開一個窗口來執(zhí)行
www.htz.pw > alter system flush buffer_cache;
System altered.
www.htz.pw > select owner from scott.htz;
OWNER ------------------------------ SYS |
3.3 DUMP數(shù)據(jù)文件中的塊
這里dump塊的目的是為了查看值是否發(fā)生了變化,以及行的標(biāo)識符信息
www.htz.pw > select file_name from dba_data_files;
FILE_NAME -------------------------------------------------------------------------------- /oracle/app/oracle/oradata/orcl1123/users01.dbf /oracle/app/oracle/oradata/orcl1123/undotbs1.dbf /oracle/app/oracle/oradata/orcl1123/sysaux01.dbf /oracle/app/oracle/oradata/orcl1123/system01.dbf /oracle/app/oracle/oradata/orcl1123/undotbs2.dbf /oracle/app/oracle/oradata/orcl1123/htz01.dbf /oracle/app/oracle/oradata/orcl1123/tbs_data.dbf /oracle/app/oracle/oradata/orcl1123/undotbs3.dbf www.htz.pw > @dump_block.sql Enter value for datafile: 4 Enter value for block_id: 6451 old 1: alter system dump datafile &datafile block &block_id new 1: alter system dump datafile 4 block 6451
System altered. |
在trace文件中可以看到如下的信息
Block header dump: 0x01001933 Object id on Block? Y seg/obj: 0x12906 csc: 0x00.24e77c itc: 3 flg: E typ: 1 - DATA brn: 0 bdba: 0x1001930 ver: 0x01 opc: 0 inc: 0 exflg: 0
Itl Xid Uba Flag Lck Scn/Fsc 0x01 0xffff.000.00000000 0x00000000.0000.00 C--- 0 scn 0x0000.0024e747 0x02 0x000d.003.000000d7 0x0140026c.0202.04 ---- 1 fsc 0x0000.00000000 0x03 0x0000.000.00000000 0x00000000.0000.00 ---- 0 fsc 0x0000.00000000 bdba: 0x01001933 data_block_dump,data header at 0x2a97c20a7c =============== tsiz: 0x1f80 hsiz: 0x14 pbl: 0x2a97c20a7c 76543210 flag=-------- ntab=1 nrow=1 frre=-1 fsbo=0x14 fseo=0x1edb avsp=0x1f14 tosp=0x1f14 0xe:pti[0] nrow=1 offs=0 0x12:pri[0] offs=0x1edb block_row_dump: tab 0, row 0, @0x1edb tl: 88 fb: --H-FL-- lb: 0x2 cc: 14 col 0: [14] 48 55 41 4e 47 54 49 4e 47 5a 48 4f 4e 47 col 1: [ 5] 49 43 4f 4c 24 col 2: *NULL* col 3: [ 2] c1 15 col 4: [ 2] c1 03 col 5: [ 5] 54 41 42 4c 45 col 6: [ 7] 78 6f 09 11 0a 2f 0e col 7: [ 7] 78 6f 09 11 0a 3b 01 col 8: [19] 32 30 31 31 2d 30 39 2d 31 37 3a 30 39 3a 34 36 3a 31 33 col 9: [ 5] 56 41 4c 49 44 col 10: [ 1] 4e col 11: [ 1] 4e col 12: [ 1] 4e col 13: [ 2] c1 02 |
4,bbed修改塊的相關(guān)的內(nèi)容
其實bbed只需要改2個地址,一個地方是改itl中的flg,更改為提交,另一個地方是清除行中的itl的值
BBED> p ktbbh struct ktbbh, 96 bytes @20 ub1 ktbbhtyp @20 0x01 (KDDBTDATA) union ktbbhsid, 4 bytes @24 ub4 ktbbhsg1 @24 0x00012906 ub4 ktbbhod1 @24 0x00012906 struct ktbbhcsc, 8 bytes @28 ub4 kscnbas @28 0x0024e77c ub2 kscnwrp @32 0x0000 sb2 ktbbhict @36 3 ub1 ktbbhflg @38 0x32 (NONE) ub1 ktbbhfsl @39 0x00 ub4 ktbbhfnx @40 0x01001930 struct ktbbhitl[0], 24 bytes @44 struct ktbitxid, 8 bytes @44 ub2 kxidusn @44 0xffff ub2 kxidslt @46 0x0000 ub4 kxidsqn @48 0x00000000 struct ktbituba, 8 bytes @52 ub4 kubadba @52 0x00000000 ub2 kubaseq @56 0x0000 ub1 kubarec @58 0x00 ub2 ktbitflg @60 0x8000 (KTBFCOM) union _ktbitun, 2 bytes @62 sb2 _ktbitfsc @62 0 ub2 _ktbitwrp @62 0x0000 ub4 ktbitbas @64 0x0024e747 struct ktbbhitl[1], 24 bytes @68 struct ktbitxid, 8 bytes @68 ub2 kxidusn @68 0x000d ub2 kxidslt @70 0x0003 ub4 kxidsqn @72 0x000000d7 struct ktbituba, 8 bytes @76 ub4 kubadba @76 0x0140026c ub2 kubaseq @80 0x0202 ub1 kubarec @82 0x04 ub2 ktbitflg @84 0x0001 (NONE) union _ktbitun, 2 bytes @86 sb2 _ktbitfsc @86 0 ub2 _ktbitwrp @86 0x0000 ub4 ktbitbas @88 0x00000000
BBED> set mode edit MODE Edit
BBED> set count 16 COUNT 16 這里有一點需要注意的是,測試平臺是X86的,如果是小機需要注意了,有一點不一樣的地方,不需要高低位轉(zhuǎn)換 BBED> modify /x 0080 offset 84 Warning: contents of previous BIFILE will be lost. Proceed? (Y/N) y File: /oracle/app/oracle/oradata/orcl1123/users01.dbf (0) Block: 6451 Offsets: 84 to 99 Dba:0x00000000 ------------------------------------------------------------------------ 00800000 00000000 00000000 00000000
<32 bytes per line>
BBED> p ktbbh.ktbbhitl[1] struct ktbbhitl[1], 24 bytes @68 struct ktbitxid, 8 bytes @68 ub2 kxidusn @68 0x000d ub2 kxidslt @70 0x0003 ub4 kxidsqn @72 0x000000d7 struct ktbituba, 8 bytes @76 ub4 kubadba @76 0x0140026c ub2 kubaseq @80 0x0202 ub1 kubarec @82 0x04 ub2 ktbitflg @84 0x8000 (KTBFCOM) union _ktbitun, 2 bytes @86 sb2 _ktbitfsc @86 0 ub2 _ktbitwrp @86 0x0000 ub4 ktbitbas @88 0x00000000
這里可以看到,下面報了行為的itl值有問題
BBED> verify DBVERIFY - Verification starting FILE = /oracle/app/oracle/oradata/orcl1123/users01.dbf BLOCK = 6451
Block Checking: DBA = 16783667, Block Type = KTB-managed data block data header at 0x2a98b8727c kdbchk: row locked by non-existent transaction table=0 slot=0 lockid=2 ktbbhitc=3 Block 6451 failed with check code 6101
DBVERIFY - Verification complete
Total Blocks Examined : 1 Total Blocks Processed (Data) : 1 Total Blocks Failing (Data) : 1 Total Blocks Processed (Index): 0 Total Blocks Failing (Index): 0 Total Blocks Empty : 0 Total Blocks Marked Corrupt : 0 Total Blocks Influx : 0 Message 531 not found; product=RDBMS; facility=BBED
BBED> p *kdbr[0] rowdata[0] ---------- ub1 rowdata[0] @8023 0x2c
BBED> set offset 8023 OFFSET 8023
BBED> dump File: /oracle/app/oracle/oradata/orcl1123/users01.dbf (0) Block: 6451 Offsets: 8023 to 8038 Dba:0x00000000 ------------------------------------------------------------------------ 2c020e0e 4855414e 4754494e 475a484f
<32 bytes per line>
BBED> modify /x 2c00 File: /oracle/app/oracle/oradata/orcl1123/users01.dbf (0) Block: 6451 Offsets: 8023 to 8038 Dba:0x00000000 ------------------------------------------------------------------------ 2c000e0e 4855414e 4754494e 475a484f
<32 bytes per line>
BBED> sum apply Check value for File 0, Block 6451: current = 0xbebc, required = 0xbebc 下面再也沒有報錯了 BBED> verify DBVERIFY - Verification starting FILE = /oracle/app/oracle/oradata/orcl1123/users01.dbf BLOCK = 6451
DBVERIFY - Verification complete
Total Blocks Examined : 1 Total Blocks Processed (Data) : 1 Total Blocks Failing (Data) : 0 Total Blocks Processed (Index): 0 Total Blocks Failing (Index): 0 Total Blocks Empty : 0 Total Blocks Marked Corrupt : 0 Total Blocks Influx : 0 Message 531 not found; product=RDBMS; facility=BBED |
6,查看bbed更改后的數(shù)據(jù)
另外開一個窗口來查看表中的數(shù)據(jù)
www.htz.pw > select owner from scott.htz;
OWNER ------------------------------ HUANGTINGZHONG |
這里可以看到數(shù)據(jù)已經(jīng)被更新了。
不過需要注意的是在update窗口,執(zhí)行rollback語句,還是可以回退的
如果在原窗口執(zhí)行rollback命令的時候,仍然會回滾記錄的。
www.htz.pw > rollback;
Rollback complete.
www.htz.pw > select owner from scott.htz;
OWNER ------------------------------ SYS |