新聞中心
在看Oracle性能優(yōu)化一書(shū)時(shí),講到用exists替代in,用表鏈接替代exists,關(guān)于前者,一般效果比較明顯,exists效率明顯比in高,但是如果要想表連接的效率比exists高,必須在from子句中,將記錄多的表放在前面,記錄少的表放后面。下文中將為大家詳細(xì)講解Oracle性能優(yōu)化可能出現(xiàn)的問(wèn)題 ,希望能夠幫助到大家。

創(chuàng)新互聯(lián)擁有一支富有激情的企業(yè)網(wǎng)站制作團(tuán)隊(duì),在互聯(lián)網(wǎng)網(wǎng)站建設(shè)行業(yè)深耕10多年,專(zhuān)業(yè)且經(jīng)驗(yàn)豐富。10多年網(wǎng)站優(yōu)化營(yíng)銷(xiāo)經(jīng)驗(yàn),我們已為成百上千中小企業(yè)提供了成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè)、外貿(mào)網(wǎng)站建設(shè)解決方案,按需制作網(wǎng)站,設(shè)計(jì)滿(mǎn)意,售后服務(wù)無(wú)憂。所有客戶(hù)皆提供一年免費(fèi)網(wǎng)站維護(hù)!
關(guān)于select... bulk collect into ... limit ...或fetch... bulk collect into ... limit ...句型:
在使用如上句型時(shí),通常我們都會(huì)用for或forall循環(huán)進(jìn)行insert/update/delete操作。
for/forall循環(huán)方法有好幾種,如
第1種:
for tp in tmp.FIRST.. tmp.LAST loop .... end loop;
第2種:
for tp in 1 .. tmp.COUNT loop .... end loop;
第3種:
for tp in indecs of tmp loop .... end loop;
上面的第1種方法有一個(gè)致使的弱點(diǎn),就是在select... bulk collect into ... limit ...或fetch... bulk collect into ... limit ...沒(méi)有取到數(shù)據(jù)時(shí),如果沒(méi)有exit,則***種方法會(huì)報(bào)錯(cuò):ORA-06502: PL/SQL: numeric or value error。因?yàn)閠mp.FIRST訪問(wèn)不存在,為空值。必須對(duì)錯(cuò)誤進(jìn)行錯(cuò)誤處理。而在嵌套的循環(huán)中,內(nèi)層的循環(huán)是不能用exit的,所有必然遇到這種錯(cuò)誤。
第2種方法不會(huì)出現(xiàn)這種問(wèn)題,第3種方法沒(méi)有試過(guò)。
借鑒網(wǎng)上的做法,給出一種使用綁定變量的批量刪除數(shù)據(jù)的存儲(chǔ)過(guò)程:
PROCEDURE RemoveBat2DjaRecords(參數(shù)) AS type RowIdArray is table of rowid index by binary_integer; rowIds RowIdArray; BEGIN loop select rowid BULK COLLECT into rowIds from 表名 where 查詢(xún)條件 and rownum <= 1000; exit when SQL%NOTFOUND; forall k in 1 .. rowIds.COUNT delete from 表名 where rowid = rowIds(k); commit; end loop; EXCEPTION when OTHERS then rollback; END RemoveBat2DjaRecords;
上面的1000條是一個(gè)可以設(shè)定的數(shù),根據(jù)你的服務(wù)器性能可以擴(kuò)大或縮小。
用exit跳出循環(huán),通常情況下,exit只跳出當(dāng)前層的循環(huán),與其它程序設(shè)計(jì)語(yǔ)言的break語(yǔ)句類(lèi)似。在嵌套的循環(huán)中,如果要直接從內(nèi)層循環(huán)跳出外面多層的循環(huán),可使用'EXIT 標(biāo)簽 When'形式的語(yǔ)句,舉例如下:
SQL> BEGIN 2 <> 3 FOR v_outerloopcounter IN 1..2 LOOP 4 <> 5 FOR v_innerloopcounter IN 1..4 LOOP 6 DBMS_OUTPUT.PUT_LINE('Outer Loop counter is ' 7 || v_outerloopcounter || 8 ' Inner Loop counter is ' || v_innerloopcounter); 9 EXIT WHEN v_innerloopcounter = 3; 10 END LOOP innerloop; 11 END LOOP outerloop; 12 END; 13 / Outer Loop counter is 1 Inner Loop counter is 1 Outer Loop counter is 1 Inner Loop counter is 2 Outer Loop counter is 1 Inner Loop counter is 3 Outer Loop counter is 2 Inner Loop counter is 1 Outer Loop counter is 2 Inner Loop counter is 2 Outer Loop counter is 2 Inner Loop counter is 3 PL/SQL procedure successfully completed.
從上面可以看出,普通情況下,exit只跳出當(dāng)前層的循環(huán)。
SQL> BEGIN 2 <> 3 FOR v_outerloopcounter IN 1..2 LOOP 4 <> 5 FOR v_innerloopcounter IN 1..4 LOOP 6 DBMS_OUTPUT.PUT_LINE('Outer Loop counter is ' 7 || v_outerloopcounter || 8 ' Inner Loop counter is ' || v_innerloopcounter); 9 EXIT outerloop WHEN v_innerloopcounter = 3; 10 END LOOP innerloop; 11 END LOOP outerloop; 12 END; 13 / Outer Loop counter is 1 Inner Loop counter is 1 Outer Loop counter is 1 Inner Loop counter is 2 Outer Loop counter is 1 Inner Loop counter is 3 PL/SQL procedure successfully completed.
從上面可以看出,exit跳出了外層的循環(huán)。
關(guān)于Oracle性能優(yōu)化可能出現(xiàn)的問(wèn)題就為大家介紹到這里,這里總結(jié)的只是一部分的內(nèi)容,大家在以后的工作中也可以細(xì)心發(fā)現(xiàn),相信大家也能夠發(fā)現(xiàn)很多的問(wèn)題,然后再努力去解決了,上文中的內(nèi)容可以供大家參考。
文章名稱(chēng):淺談Oracle性能優(yōu)化可能出現(xiàn)的問(wèn)題
本文路徑:http://fisionsoft.com.cn/article/ccshojs.html


咨詢(xún)
建站咨詢(xún)
