视窗
loading...
您现在的位置:首页 > IT认证 > oracle认证 >

Oracle事务表实验


Oracle事务表实验

 回滚段头中,有一项非常重要的信息,就是事务表。对事务表频繁的访问,可能会造成回滚段头的争用。了解什么样的操作会访问事务表,对于了解回滚段头争用的原因非常重要。下面我们来做一些实验来验证一下,什么样的操作才会访问事务表。
   
    首 先简单介绍一个视图,备份x$bh.对这个视图我想大家都有一定的了解,bh即buffer header 的简写。在buffer  header中有 一个TCH 列,表示块被访问的次数。我们通过他来验证事务表什么时候被访问。需要注意的是。TCH列每3秒,才会重新计算一次,3秒之内无论访问某一个 块多少次。TCH列只会增加1.
   
    在会话A开启一个事务后:
   
    步骤一:通过v$transaction视图找到XID
   
    SQL> select xidusn,ubablk,ubafil from v$transaction;
   
    XIDUSN     UBABLK     UBAFIL
   
    ---------- ---------- ----------
   
    13         97          5
   
    步骤二:通过回滚段编号,可得知事务所占回滚段名,并用此查找事务头块号,文件号
   
    SQL> select header_block,header_file from dba_segments where segment_name='_SYSSMU13$';
   
    HEADER_BLOCK HEADER_FILE
   
    ------------ -----------
   
    41           5
   
    步骤三:查看x$bh视图中,TCH值的增加。
   
    SQL> select addr,tch from x$bh where dbarfil=5 and dbablk=41;
   
    ADDR            TCH
   
    -------- ----------
   
    080B5208         41
   
    步骤四:查找完TCH后,马上执行要测试的命令(会话B),
   
    SQL> select * from jj_3;
   
    ID NA
   
    ---------- --
   
    1 aa
   
    2 aa
   
    3 aa
   
    4 aa
   
    5 CN
   
    步骤五:再次查看x$bh视图
   
    SQL> select addr,tch from x$bh where dbarfil=5 and dbablk=41;
   
    ADDR            TCH
   
    -------- ----------
   
    080B5208         42
   
    注意:步骤三四五应尽快完成。避免oracle的其他内部操作影响测试结果。(因为oracle内部的操作也会造成回滚段头的tch值增加,特别在10G中,这种情况更为明显,不过我没有跟踪是什么oracle的内部操作造成的)
   
    小结:从结果集来看,在另一会话中访问未提交数据的select语句会访问事务表,那么其他的DML操作呢?(希望大家也都试试,我的结果是都会增加TCH值)。上面我的步骤四是全表扫描。如果我的表有两个块,分别是块一块二,在块一中修改行A,按照rowid访问块一中的行B,这样会访问事务表吗?如果

按照rowid访问块二中的行,会访问事务表吗?下面我来实验下看结果是什么:

步一:利用函数查看该表的块号。

SQL> select rowid,dbms_rowid.rowid_block_number(rowid) from jj_3;

ROWID DBMS_ROWID.ROWID_BLOCK_NUMBER(ROWID)

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

AAAMvjAAKAAAAEdAAA 285

AAAMvjAAKAAAAEdAAB 285

AAAMvjAAKAAAAEdAAC 285

AAAMvjAAKAAAAEeAAA 286

步二: 在B会话中通过AAAMvjAAKAAAAEdAAC修改表。

SQL> update jj_3 set id=10 where rowid='AAAMvjAAKAAAAEdAAC';

已更新 1 行。

步三: 在A会话中通过AAAMvjAAKAAAAEdAAA查看行

SQL> select * from jj_3 where rowid='AAAMvjAAKAAAAEdAAA';

ID NA

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

4 aa

在做步一和二之前,先查看一下X$BH,因为他会因为oracle的内部操作而增加,

实验前查看结果:

SQL> select addr,tch from x$bh where dbarfil=5 and dbablk=41;

ADDR TCH

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

080B51BC 63

实验后查看结果:

SQL> select addr,tch from x$bh where dbarfil=5 and dbablk=41;

ADDR TCH

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

080B51BC 64

结论一:在块一中修改行A,按照rowid访问块一中的行B,这样会访问事务表;再试试不同的块

操作前先查看下X$BH:

SQL> select addr,tch from x$bh where dbarfil=5 and dbablk=41;

ADDR TCH

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

080B51BC 67

接着刚才的实验,我又访问了不同的块:

SQL> select * from jj_3 where rowid='AAAMvjAAKAAAAEeAAA';

ID NA

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

4 aa

再次查看X$BH的结果是:

SQL> select addr,tch from x$bh where dbarfil=5 and dbablk=41;

ADDR TCH

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

080B51BC 67

结果很明显了,用rowid访问不同的块,是不会增加TCH值的。也就是说不会有CR块产生。

在晶晶实验六中,已经证明了在生成CR块时,oracle可以根据数据块头部的ITL槽中的UBA,找到存放数据块回滚信息的回 滚块和回滚记录,通过这个UBA就可以构造CR块咯,oracle为什么还要再去访问事务表呢?这是因为,oracle的提交有时会 是延迟提交。oracle并不清除延迟提交所涉及的块中的事务信息,如:事务所占ITL槽和行锁。而把清除事务信息这个操作 放到了以后的块清除中(块清除在以后的实验会详细讲述),oracle这样做的目的是为加快提交速度。如果一个事务涉及到了过多的块,单单是提交时清除每个块中的事务信息就需要耗费很长时间。这降低了提交速度。有可能使提交成为最易 引起争用的操作。当事务提交时,对事务所涉及的块,不做任何操作,块将保持事务仍在持续时的信息。当一个select操作 查询到这个块时,ITL槽中的提交标志为未提交,但实际上这个事务是已经提交的。就是因为有了延迟提交oracle无法根 据ITL槽中的提交标志来判断一个块中的事务是否真的提交。他必须根据ITL中的XID 去访问事务表。才能确定此块中的事务是否真的提交。在生成CR块前,oracle先要判断是否真的有必要为此块生成CR块。这就要去访问事务表。

闂侀潧妫岄崑锟�

闂侀潧妫岄崑锟�

闂侀潧妫欓崝鏇㈠储閵堝洦瀚婚柨婵嗘嫅缁憋綁鏌¢崟顐︻€楅柟铚傚嵆閹囧醇閻斿摜绉柣鐘叉搐閻°劌危閹达箑违闁跨噦鎷�
闂佸搫鐗滈崜娑㈡偟椤栫偞鐒鹃柕濞垮劚閻庤菐閸ワ絽澧插ù鐓庢嚇瀵爼濡烽敂鍓у煃婵炲瓨绮岀花鑲╄姳娴煎瓨鍤傞柡鍐ㄥ€荤粔褰掓煥濞戣櫕瀚�闁诲海鏁搁、濠偯归崱妯诲闁伙絽鏈悾鍗炃庨崶锝呭⒉濞寸厧鎳橀獮瀣箣濠婂嫮鎷ㄩ梺鍛婃⒐缁嬫帡鎯囨导鏉戝唨闁搞儯鍔嶉~鏍庨崶锝呭⒉濞寸厧鎳橀幆鍐礋椤愩垺鐦旀繝銏f硾鐎氬摜妲愰敓锟�闂佺懓鐡ㄩ崹鍐测堪閹寸姳鐒婂┑鐘叉搐濞呫垹霉閿濆棛鐭庨柍褜鍓欓幊鎰枔閹达附鍋嬮柛顐ゅ枑缂嶁偓闂佹垝鐒﹂妵鐐电礊閺冨牆绾ч柛鎰硶缁€锟�闁诲簼绲婚~澶愬垂濠婂嫮顩锋い鎺戝暞缁侇噣寮堕悙鍨珪婵炲牊鍨剁粚閬嶅焺閸愌呯婵犵鈧啿鈧懓锕㈡担鍓插殨闁稿本绻嶉崬鎾煙鐎涙ḿ澧繝鈧担鍦懝闁割煈鍋呯紞鈧梺鐟扮摠閻楃偟鎹㈠顑芥灃闁哄洦鐭换鍡涙煙椤撗冪仴妞ゆ洦鍓熷畷锝嗙節閸愨晩妲梺鑹伴哺濮婂鏌堥幘顔肩闁瑰瓨绮嶇划锕傛煥濞戞ɑ婀版繝鈧幍顔惧崥婵炲棗娴风粣妤冪磼閺傛鍎忕€规挸妫濆畷姘舵偐缂佹ḿ褰戦梺鎸庡喕閹凤拷闁诲海鏁搁幊鎾舵暜椤愶箑绀嗘繛鎴灻弫鍫曟倵绾拋娼愰柛銊︾矋缁傛帡顢楁担绋啃梺瑙勬緲缁绘垿寮鐣岊浄婵せ鍋撻柍褜鍓欓崐鍝ョ礊鐎n喗鍎嶉柛鏇ㄥ帎瑜版帗鐓€妞ゆ帒锕︾粈锟�闂佽壈椴稿濠氭焾閹绢喖妫橀柣鐔稿绾偓闂佹寧绋掑畝鎼佸磻閺嶃劎顩烽柨鐕傛嫹:webmaster@jscj.com闂侀潧妫岄崑鎾绘煟椤厾绁烽柣锔跨矙閺佸秹鏁撻敓锟�4008816886

相关文章

无相关信息
更新时间2022-03-13 11:11:03【至顶部↑】
联系我们 | 邮件: webmaster@jscj.com | 客服热线电话:4008816886(QQ同号) |  婵犵數濮烽弫鍛婃叏閻戣棄鏋侀柛娑橈攻閸欏繘鏌i幋锝嗩棄闁哄绶氶弻鐔兼⒒鐎靛壊妲紒鐐劤濞硷繝寮婚悢琛″亾閻㈢櫥鐟版毄缂傚倷璁查崑鎾斥攽閻樺弶澶勯柣鎾冲暟閹茬ǹ饪伴崼婵堫槶濠殿喗枪濞夋稒顢婇梻浣告啞濞诧箓宕规导鏉戠闁规儼濮ら悡鏇㈡煃閳轰礁鏋ゆ繛鍫熸⒐閵囧嫯绠涢敐鍕仐闂佸搫鏈粙鎴﹀煝鎼淬倗鐤€闁哄洨濯崯瀣⒒娴e憡鎯堥柣顓烆槺缁辩偞绗熼埀顒勬偘椤曗偓瀹曞爼顢楁径瀣珨闂備礁鎲℃笟妤呭窗濡ゅ懏鍎婃繝濠傜墛閳锋帒霉閿濆懏鍤堢憸鐗堝俯閺佸嫰鏌涢埄鍐槈缂佺姵鐓¢弻娑㈠Ψ椤旂厧顫梺绋款儐钃遍柕鍥у瀵潙螖閳ь剚绂嶆ィ鍐╁€甸悷娆忓缁€鈧紓鍌氱Т閿曨亪濡存担绯曟瀻闁规儳纾悡鎴︽⒑闂堟冻绱¢柛鏇炲绾偓濠电姷鏁告慨鐑藉极閸涘﹥鍙忛柣鎴f閺嬩線鏌涘☉姗堟敾闁告瑥绻戦妵鍕箻閸楃偟浠肩紒鐐劤椤兘寮婚悢鐓庣鐟滃繒鏁☉銏$厽闁规儳鐡ㄧ粈瀣煛鐏炵偓绀冪€垫澘瀚埀顒婄秵娴滅偞绂掗幘顔解拺闁稿繐鍚嬮妵鐔兼煕閵娿倕宓嗛柛鈹垮灲楠炴ê煤缂佹ɑ娅囬梻渚€娼х换鍡涘疾濠婂應鍋撻棃娑氱劯婵﹥妞藉Λ鍐ㄢ槈濮橆剦鏆繝纰樻閸嬪懘鎮烽埡鍕紓闂備胶纭堕崜婵婂綘婵炲瓨绮嶇划鎾诲蓟閿熺姴纾兼慨姗嗗墰濞堝綊姊洪崨濠冣拻闁哥姵鐗犲濠氭偄閼测晛绁﹂梺鍓茬厛閸犳碍瀵奸崼銉︹拺閺夌偞澹嗛崝宥夋煙閻熺増鍠樼€殿噮鍋婇獮妯肩磼濡粯顏熼梻浣芥硶閸o箓骞忛敓锟�

付款方式留言簿投诉中心网站纠错二维码手机版

客服电话: