在Oracle 中,對於一個提交的sql語句,存在兩種可選的解析過程, 一種叫做硬解析,一種叫做軟解析.
一個硬解析需要經解析,制定執行路徑,最佳化訪問計劃等許多的步驟.硬解釋不僅僅耗費大量的cpu,更重要的是會佔據重要的們閂(latch)資源,嚴重的影響系統的規模的擴大(即限制了系統的並發行), 而且引起的問題不能通過增加記憶體條和cpu的數量來解決。之所以這樣是因為門閂是為了順序訪問以及修改一些記憶體地區而設定的,這些記憶體地區是不能被同時修改。當一個sql語句提交後,oracle會首先檢查一下共用緩衝池(shared pool)裡有沒有與之完全相同的語句,如果有的話只須執行軟分析即可,否則就得進行硬分析。
而唯一使得oracle 能夠重複利用執行計畫的方法就是採用綁定變數。綁定變數的實質就是用於替代sql語句中的常量的替代變數。綁定變數能夠使得每次提交的sql語句都完全一樣。
1、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; 2、pl/sqlpl/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中,引用變數即是引用綁定變數。
但當引用的值不是變數(常量或者運算式)且要多次重複執行時,也需要動態綁定變數:
DECLARE
c_temp site%ROWTYPE;
TYPE cursortype IS REF CURSOR;
cur_temp cursortype;
BEGIN
OPEN cur_temp FOR('select * from site where site_id=:1')
USING 91;
LOOP
FETCH cur_temp
INTO c_temp;
EXIT WHEN cur_temp%NOTFOUND;
EXECUTE IMMEDIATE 'insert into b values (:1)'
USING c_temp.site_id;
END LOOP;
CLOSE cur_temp;
COMMIT;
END;