成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

淺談Oracle性能優(yōu)化可能出現(xiàn)的問題

數(shù)據(jù)庫 Oracle
在看Oracle性能優(yōu)化一書時,講到用exists替代in,用表鏈接替代exists,關(guān)于前者,一般效果比較明顯,exists效率明顯比in高,但是如果要想表連接的效率比exists高,必須在from子句中,將記錄多的表放在前面,記錄少的表放后面。

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

關(guān)于select... bulk collect into ... limit ...或fetch... bulk collect into ... limit ...句型:

在使用如上句型時,通常我們都會用for或forall循環(huá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種方法有一個致使的弱點,就是在select... bulk collect into ... limit ...或fetch... bulk collect into ... limit ...沒有取到數(shù)據(jù)時,如果沒有exit,則***種方法會報錯:ORA-06502: PL/SQL: numeric or value error。因為tmp.FIRST訪問不存在,為空值。必須對錯誤進行錯誤處理。而在嵌套的循環(huán)中,內(nèi)層的循環(huán)是不能用exit的,所有必然遇到這種錯誤。

第2種方法不會出現(xiàn)這種問題,第3種方法沒有試過。

借鑒網(wǎng)上的做法,給出一種使用綁定變量的批量刪除數(shù)據(jù)的存儲過程:

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 查詢條件 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條是一個可以設(shè)定的數(shù),根據(jù)你的服務(wù)器性能可以擴大或縮小。

用exit跳出循環(huán),通常情況下,exit只跳出當前層的循環(huán),與其它程序設(shè)計語言的break語句類似。在嵌套的循環(huán)中,如果要直接從內(nèi)層循環(huán)跳出外面多層的循環(huán),可使用'EXIT 標簽 When'形式的語句,舉例如下:

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只跳出當前層的循環(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)的問題就為大家介紹到這里,這里總結(jié)的只是一部分的內(nèi)容,大家在以后的工作中也可以細心發(fā)現(xiàn),相信大家也能夠發(fā)現(xiàn)很多的問題,然后再努力去解決了,上文中的內(nèi)容可以供大家參考。

 

責任編輯:迎迎 來源: 中國IT實驗室
相關(guān)推薦

2009-04-24 10:49:57

Oracle性能優(yōu)化錯誤

2009-05-04 09:52:49

Oracle優(yōu)化排序

2011-07-18 18:01:34

buffer cach

2010-04-14 12:51:10

Oracle性能

2009-06-29 10:19:42

.NET Micro性能優(yōu)化

2018-01-09 16:56:32

數(shù)據(jù)庫OracleSQL優(yōu)化

2009-06-30 11:23:02

性能優(yōu)化

2011-08-02 21:16:56

查詢SQL性能優(yōu)化

2010-04-13 16:08:24

Oracle數(shù)據(jù)插入

2010-11-15 16:20:33

Oracle系統(tǒng)優(yōu)化

2021-03-21 23:43:22

線程編程安全

2010-04-23 14:48:26

Oracle性能優(yōu)化

2017-08-25 15:28:20

Oracle性能優(yōu)化虛擬索引

2010-05-05 11:48:27

Oracle設(shè)計開發(fā)階

2010-04-07 09:21:03

Oracle RAC

2010-04-21 17:09:28

Oracle啟動模式

2010-04-21 12:49:57

Oracle性能

2010-09-13 10:45:46

無線網(wǎng)絡(luò)性能

2009-06-30 16:08:19

性能問題代碼寫法

2023-12-29 12:12:04

廣告性能優(yōu)化
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 天堂一区 | 中文字幕第一页在线 | 男女激情网站免费 | www.伊人.com| 日日操操 | 97超碰人人| 色狠狠桃花综合 | 日韩欧美在线一区 | 青青久久av北条麻妃海外网 | 99精彩视频 | 国产在线观看免费 | 色综合视频 | 91在线精品秘密一区二区 | 日韩一区二区福利 | 国产片侵犯亲女视频播放 | 欧美日韩一区二区在线 | 男女网站免费观看 | 影音先锋亚洲资源 | 成人久久久 | 久久久久久亚洲精品 | 日本不卡一区 | 少妇一区二区三区 | 亚洲精品成人网 | 精产嫩模国品一二三区 | 亚洲一区二区三区免费 | 99久久免费精品视频 | av黄色在线 | 国产精品2 | 欧美在线不卡 | 99久久精品免费看国产高清 | 免费av播放| 一区二区三区韩国 | 亚洲一区二区视频 | 国产精品日日摸夜夜添夜夜av | 国产精品特级片 | 天天操操| 久久精品视频免费看 | www.黄色在线观看 | 成人免费淫片aa视频免费 | 国产东北一级毛片 | 欧美日韩在线国产 |