程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle數據庫基礎 >> 用Oracle綁定變量替代sql語句裡常量

用Oracle綁定變量替代sql語句裡常量

編輯:Oracle數據庫基礎

在實際相關應用操作過程中的具體操作中唯一能使得Oracle 能重復的利用執行計劃的相關方法就是用綁定變量的方法。其實Oracle綁定變量的實質就是用於替代sql語句中的常量的替代變量。

Oracle 中,對於一個提交的sql語句,存在兩種可選的解析過程, 一種叫做硬解析,一種叫做軟解析.

一個硬解析需要經解析,制定執行路徑,優化訪問計劃等許多的步驟.硬解釋不僅僅耗費大量的cpu,更重要的是會占據重要的們闩(latch)資源,嚴重的影響系統的規模的擴大(即限制了系統的並發行), 而且引起的問題不能通過增加內存條和cpu的數量來解決。

之所以這樣是因為門闩是為了順序訪問以及修改一些內存區域而設置的,這些內存區域是不能被同時修改。當一個sql語句提交後,Oracle 會首先檢查一下共享緩沖池(shared pool)裡有沒有與之完全相同的語句,如果有的話只須執行軟分析即可,否則就得進行硬分析。

而唯一使得Oracle 能夠重復利用執行計劃的方法就是采用綁定變量。綁定變量的實質就是用於替代sql語句中的常量的替代變量。綁定變量能夠使得每次提交的sql語句都完全一樣。

綁定變量只是起到占位的作用,同名的綁定變量並不意味著在它們是同樣的,在傳遞時要考慮的是傳遞的值與綁定變量出現順序的對位,而不是綁定變量的名稱。

  1. create table t (a varchar2(20),b varchar2(20)); 

如何使用Oracle綁定變量

  1. declare  
  2. v_sql varchar2(50);  
  3. begin  
  4. for i in 1..100000 loop  
  5. v_sql :'insert into t values (:1,:2)';  
  6. execute immediate v_sql using 'a'||i,'b'||i;  
  7. end loop;  
  8. commit;  
  9. end;  
  10. /  

清表

  1. truncate table t; 

不使用綁定變量

  1. declare  
  2. begin  
  3. for i in 1..100000 loop  
  4. insert into t values ('a'||i,'b'||i);  
  5. end loop;  
  6. commit;  
  7. end;  
  8. /  
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved