oracle 綁定變量(bind variable)

          Posted on 2009-06-15 19:20 林光炎 閱讀(649) 評論(0)  編輯  收藏 所屬分類: ORACLE
          oracle 中,對于一個提交的sql語句,存在兩種可選的解析過程, 一種叫做硬解析,一種叫做軟解析.
          一個硬解析需要經解析,制定執行路徑,優化訪問計劃等許多的步驟.硬解釋不僅僅耗費大量的cpu,更重要的是會占據重要的們閂(latch)資源,嚴重的影響系統的規模的擴大(即限制了系統的并發行), 而且引起的問題不能通過增加內存條和cpu的數量來解決。
          之所以這樣是因為門閂是為了順序訪問以及修改一些內存區域而設置的,這些內存區域是不能被同時修改。當一個sql語句提交后,oracle會首先檢查一下共享緩沖池(shared pool)里有沒有與之完全相同的語句,如果有的話只須執行軟分析即可,否則就得進行硬分析。
          而唯一使得oracle 能夠重復利用執行計劃的方法就是采用綁定變量。綁定變量的實質就是用于替代sql語句中的常量的替代變量。綁定變量能夠使得每次提交的sql語句都完全一樣。
          普通sql語句:

          SELECT fname, lname, pcode FROM cust WHERE id = 674;
          SELECT fname, lname, pcode FROM cust WHERE id = 234;
          SELECT fname, lname, pcode FROM cust WHERE id = 332;
          含綁定變量的sql 語句:
          SELECT fname, lname, pcode FROM cust WHERE id = :cust_no;

          Sql*plus 中使用綁定變量:
          sql> variable x number;
          sql> exec :x := 123;
          sql> SELECT fname, lname, pcode FROM cust WHERE id =:x;

           

          pl/sql
          pl/sql很多時候都會自動綁定變量而無需編程人員操心,即很多你寫得sql語句都會自動利用綁定變量,如下例所示:


          create or replace procedure dsal(p_empno in number)
          as
          begin
          update emp
          set sal=sal*2
          where empno = p_empno;
          commit;
          end;
          /

          也許此時你會想要利用綁定變量來替代p_empno,但是這是完全沒有必要的,因為在pl/sql中,引用變量即是引用綁定變量。
          但是在pl/sql中動態sql并不是這樣。
          在vb,java以及其他應用程序中都得顯式地利用綁定變量。
          對于綁定變量的支持不僅僅限于oracle,其他RDBMS向SQLSERVER也支持這一特性。
          但是并不是任何情況下都需要使用綁定變量, 下面是兩種例外情況:
          1.對于隔相當一段時間才執行一次的sql語句,這是利用綁定變量的好處會被不能有效利用優化器而抵消
          2.數據倉庫的情況下。

          posts - 104, comments - 33, trackbacks - 0, articles - 0

          Copyright © 林光炎

          主站蜘蛛池模板: 汉中市| 阳曲县| 新余市| 响水县| 庆云县| 彭泽县| 清徐县| 海原县| 花莲县| 兴文县| 大英县| 紫阳县| 伽师县| 宕昌县| 涿州市| 万安县| 汝州市| 沭阳县| 广安市| 大姚县| 兴宁市| 金乡县| 万盛区| 名山县| 云安县| 登封市| 莆田市| 交口县| 繁峙县| 嘉峪关市| 涿鹿县| 辽宁省| 库伦旗| 阿拉善盟| 敦煌市| 尼木县| 额尔古纳市| 抚顺市| 临清市| 揭东县| 通海县|