激情五月天婷婷,亚洲愉拍一区二区三区,日韩视频一区,a√天堂中文官网8

<ul id="buwfs"><strike id="buwfs"><strong id="buwfs"></strong></strike></ul>
    <output id="buwfs"></output>
  • <dfn id="buwfs"><source id="buwfs"></source></dfn>
      <dfn id="buwfs"><td id="buwfs"></td></dfn>
      <div id="buwfs"><small id="buwfs"></small></div>
      <dfn id="buwfs"><source id="buwfs"></source></dfn>
      1. <dfn id="buwfs"><td id="buwfs"></td></dfn>
        始創(chuàng)于2000年 股票代碼:831685
        咨詢熱線:0371-60135900 注冊有禮 登錄
        • 掛牌上市企業(yè)
        • 60秒人工響應(yīng)
        • 99.99%連通率
        • 7*24h人工
        • 故障100倍補償
        全部產(chǎn)品
        您的位置: 網(wǎng)站首頁 > 幫助中心>文章內(nèi)容

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

        發(fā)布時間:  2012/8/14 16:59:00

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

            關(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)。
         


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

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

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

        0371-60135900
        7*24小時客服服務(wù)熱線