複製鏈接
請複製以下鏈接發送給好友

變量綁定

鎖定
變量綁定(bind variable) [1] 
是指在sql語句的條件中使用變量而不是常量。比如shared pool裏有兩條sql語句,
select * from tab1 where col1=1;
select * from tab1 where col1=2;
對oracle數據庫來説,這是兩條完全不同的SQL,對這兩條語句都需要進行hard parse。因為oracle會根據sql語句的文本去計算每個字符在內存裏的hash值,因此雖然上述兩條SQL只有一個字符不一樣,oracle根據hash算法在內存中得到的hash地址就不一樣,所以oracle就會認為這是兩條完全不同的語句。而如果將上述SQL改寫成select * from tab1 where col1=:var1;,然後通過對變量var1的賦值去查詢,那麼oracle對這條語句第一次會進行hard parse,以後就只進行soft parse。假設某條語句被重複執行了幾十萬次,那麼使用bind var帶來的好處是巨大的。一個應用程序如果bind var使用不充分,那麼幾乎一定會伴隨着嚴重的性能問題。
綁定變量是相對文本變量來講的,所謂文本變量是指在SQL直接書寫查詢條件,這樣的SQL在不同條件下需要反覆解析,綁定變量是指使用變量來代替直接書寫條件,查詢bind value在運行時傳遞,然後綁定執行。優點是減少硬解析,降低CPU的爭用,節省shared_pool ;缺點是不能使用histogram,sql優化比較困難
中文名
變量綁定
外文名
bind variable
相    對
文本變量
格    式
變量名:=變量值
類    型
計算機術語

變量綁定SQL語句實現

首先用var進行聲明,確定變量名及類型,再使用exec賦值。格式為“:變量名:=變量值”。“:=”為賦值符號,例如“SQL> exec :i:=:i+1;”。使用時通過“:變量名”方式調用。 例如: SQL> var i varchar2(10); SQL> exec :i:='sql'; SQL> select * fromtable_name where name=:i; [2] 

變量綁定Java編程實現

利用prepareStatement創建對象,結合使用setXXX 系列方法,可以為不同數據類型的綁定變量進行賦值。
在sql字符串中,使用“?”代替變量出現位置,並使用setString方法對“?”所在位置設置替換變量。
例如:
String var="1";
String sql="select *from table_name where ID =?";
Connection c = DriverManager.getConnection(dbUrl, user, key);
PreparedStatement p = c.prepareStatement(sql);
p.setString(1, var);
ResultSet r = p.executeQuery();
參考資料