oracle 綁定變數(bind variable)

來源:互聯網
上載者:User
綁定變數  在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 := 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.資料倉儲的情況下。
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.