1. <var id="fe6gj"></var>

    <rp id="fe6gj"><nav id="fe6gj"></nav></rp>

    <noframes id="fe6gj"><cite id="fe6gj"></cite>

    <ins id="fe6gj"><button id="fe6gj"><p id="fe6gj"></p></button></ins>
    1. <tt id="fe6gj"><i id="fe6gj"><sub id="fe6gj"></sub></i></tt>
        始創于2000年 股票代碼:831685
        咨詢熱線:0371-60135900 注冊有禮 登錄
        • 掛牌上市企業
        • 60秒人工響應
        • 99.99%連通率
        • 7*24h人工
        • 故障100倍補償
        您的位置: 網站首頁 > 幫助中心>文章內容

        淺談Oracle性能優化可能出現的問題

        發布時間:  2012/8/14 16:59:00

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

            關于select... bulk collect into ... limit ...或fetch... bulk collect into ... limit ...句型:-
         


            在使用如上句型時,通常我們都會用for或forall循環進行insert/update/delete操作。

            for/forall循環方法有好幾種,如  

            第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 ...沒有取到數據時,如果沒有exit,則第一種方法會報錯:ORA-06502: PL/SQL: numeric or value error。因為tmp.FIRST訪問不存在,為空值。必須對錯誤進行錯誤處理。而在嵌套的循環中,內層的循環是不能用exit的,所有必然遇到這種錯誤。

            第2種方法不會出現這種問題,第3種方法沒有試過。

            借鑒網上的做法,給出一種使用綁定變量的批量刪除數據的存儲過程:


            PROCEDURE RemoveBat2DjaRecords(參數)    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條是一個可以設定的數,根據你的服務器性能可以擴大或縮小。

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


        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跳出了外層的循環。
         


        本文出自:億恩科技【www.endtimedelusion.com】

        服務器租用/服務器托管中國五強!虛擬主機域名注冊頂級提供商!15年品質保障!--億恩科技[ENKJ.COM]

      1. 您可能在找
      2. 億恩北京公司:
      3. 經營性ICP/ISP證:京B2-20150015
      4. 億恩鄭州公司:
      5. 經營性ICP/ISP/IDC證:豫B1.B2-20060070
      6. 億恩南昌公司:
      7. 經營性ICP/ISP證:贛B2-20080012
      8. 服務器/云主機 24小時售后服務電話:0371-60135900
      9. 虛擬主機/智能建站 24小時售后服務電話:0371-60135900
      10. 專注服務器托管17年
        掃掃關注-微信公眾號
        0371-60135900
        Copyright© 1999-2019 ENKJ All Rights Reserved 億恩科技 版權所有  地址:鄭州市高新區翠竹街1號總部企業基地億恩大廈  法律顧問:河南亞太人律師事務所郝建鋒、杜慧月律師   京公網安備41019702002023號
          0
         
         
         
         

        0371-60135900
        7*24小時客服服務熱線

         
         
        av不卡不卡在线观看_最近2018年中文字幕_亚洲欧美一区二区三区_一级A爱做片免费观看国产_日韩在线中文天天更新_伊人中文无码在线