在實際相關應用操作過程中的具體操作中唯一能使得Oracle 能重復的利用執行計劃的相關方法就是用綁定變量的方法。其實Oracle綁定變量的實質就是用於替代sql語句中的常量的替代變量。
Oracle 中,對於一個提交的sql語句,存在兩種可選的解析過程, 一種叫做硬解析,一種叫做軟解析.
一個硬解析需要經解析,制定執行路徑,優化訪問計劃等許多的步驟.硬解釋不僅僅耗費大量的cpu,更重要的是會占據重要的們闩(latch)資源,嚴重的影響系統的規模的擴大(即限制了系統的並發行), 而且引起的問題不能通過增加內存條和cpu的數量來解決。
之所以這樣是因為門闩是為了順序訪問以及修改一些內存區域而設置的,這些內存區域是不能被同時修改。當一個sql語句提交後,Oracle 會首先檢查一下共享緩沖池(shared pool)裡有沒有與之完全相同的語句,如果有的話只須執行軟分析即可,否則就得進行硬分析。
而唯一使得Oracle 能夠重復利用執行計劃的方法就是采用綁定變量。綁定變量的實質就是用於替代sql語句中的常量的替代變量。綁定變量能夠使得每次提交的sql語句都完全一樣。
綁定變量只是起到占位的作用,同名的綁定變量並不意味著在它們是同樣的,在傳遞時要考慮的是傳遞的值與綁定變量出現順序的對位,而不是綁定變量的名稱。
- create table t (a varchar2(20),b varchar2(20));
如何使用Oracle綁定變量
- declare
- v_sql varchar2(50);
- begin
- for i in 1..100000 loop
- v_sql := 'insert into t values (:1,:2)';
- execute immediate v_sql using 'a'||i,'b'||i;
- end loop;
- commit;
- end;
- /
清表
- truncate table t;
不使用綁定變量
- declare
- begin
- for i in 1..100000 loop
- insert into t values ('a'||i,'b'||i);
- end loop;
- commit;
- end;
- /