国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > Oracle > 正文

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

2019-09-08 23:30:45
字體:
來源:轉載
供稿:網(wǎng)友

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

   關于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)中,內層的循環(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ù),根據(jù)你的服務器性能可以擴大或縮小。

   用exit跳出循環(huán),通常情況下,exit只跳出當前層的循環(huán),與其它程序設計語言的break語句類似。在嵌套的循環(huán)中,如果要直接從內層循環(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)。 

Oracle

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 拜泉县| 康保县| 日照市| 凤台县| 奈曼旗| 苏尼特左旗| 抚松县| 秭归县| 高州市| 五家渠市| 潞西市| 含山县| 武隆县| 张家川| 嵊州市| 虞城县| 温宿县| 瑞丽市| 旬邑县| 大姚县| 望城县| 普宁市| 双鸭山市| 冀州市| 南和县| 同仁县| 淅川县| 西和县| 孟州市| 陇西县| 鸡泽县| 永川市| 湖州市| 从化市| 扶余县| 余江县| 新化县| 枣阳市| 双鸭山市| 无锡市| 曲周县|