真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

bbed修改itl值,手動提交事務(wù)

數(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


分享題目:bbed修改itl值,手動提交事務(wù)
標(biāo)題URL:http://weahome.cn/article/jspoih.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部