天天看點

綁定變量及其優點

什麼是綁定變量(bind variable)

bind var是指在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優化比較困難