oracle 繫結變數(bind variable)
在oracle 中,對於一個提交的sql語句,存在兩種可選的解析過程, 一種叫做硬解析,一種叫做軟解析.
一個硬解析需要經解析,制定執行路徑,最佳化訪問計劃等許多的步驟.硬解釋不僅僅耗費大量的cpu,更重要的是會佔據重要的們閂(latch)資源,嚴重的影響系統的規模的擴大(即限制了系統的併發行), 而且引起的問題不能透過增加記憶體條和cpu的數量來解決。之所以這樣是因為門閂是為了順序訪問以及修改一些記憶體區域而設定的,這些記憶體區域是不能被同時修改。當一個sql語句提交後,oracle會首先檢查一下共享緩衝池(shared pool)裡有沒有與之完全相同的語句,如果有的話只須執行軟分析即可,否則就得進行硬分析。
而唯一使得oracle 能夠重複利用執行計劃的方法就是採用繫結變數。繫結變數的實質就是用於替代sql語句中的常量的替代變數。繫結變數能夠使得每次提交的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;
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;
pl/sql
pl/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;
/
as
begin
update emp
set sal=sal*2
where empno = p_empno;
commit;
end;
/
也許此時你會想要利用繫結變數來替代p_empno,但是這是完全沒有必要的,因為在pl/sql中,引用變數即是引用繫結變數。
但是在pl/sql中動態sql並不是這樣。
在vb,java以及其他應用程式中都得顯式地利用繫結變數。
對於繫結變數的支援不僅僅限於oracle,其他RDBMS向SQLSERVER也支援這一特性。
但是並不是任何情況下都需要使用繫結變數, 下面是兩種例外情況:
1.對於隔相當一段時間才執行一次的sql語句,這是利用繫結變數的好處會被不能有效利用最佳化器而抵消
2.資料倉儲的情況下。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/8183736/viewspace-430083/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- [SQL]oracle 繫結變數(bind variable)[轉載]SQLOracle變數
- Oracle繫結變數分級(Bind Graduation)Oracle變數
- 繫結變數之繫結變數窺探(Bind Peeking)變數
- oracle bind value peeking繫結變數窺視Oracle變數
- 繫結變數和BIND PEEKING變數
- Oracle 繫結變數Oracle變數
- v$sql_bind_capture 獲取繫結變數SQLAPT變數
- Oracle之繫結變數Oracle變數
- v$sql_bind_capture 獲取繫結變數資訊SQLAPT變數
- ORACLE 繫結變數用法總結Oracle變數
- Oracle 繫結變數窺探Oracle變數
- Oracle 繫結變數 詳解Oracle變數
- 透過v$sql_bind_capture 檢視繫結變數。SQLAPT變數
- 通過v$sql_bind_capture 檢視繫結變數。SQLAPT變數
- 繫結變數、BIND PEEKING、histogram(柱狀圖)的使用變數Histogram
- Oracle 變數繫結與變數窺視合集Oracle變數
- 【ORACLE】Oracle繫結變數知識梳理Oracle變數
- ORACLE 獲取繫結變數值Oracle變數
- oracle繫結變數的測試Oracle變數
- oracle繫結變數窺視(zt)Oracle變數
- 繫結變數、BIND PEEKING、histogram(柱狀圖)的使用(zt)變數Histogram
- 繫結變數變數
- ORACLE優化實戰(繫結變數)Oracle優化變數
- 【原創】Oracle 變數繫結與變數窺視合集Oracle變數
- Event 10053 執行計劃 繫結變數 Bind peeking變數
- 繫結變數優缺點、使用、繫結變數窺探、 Oracle自適應共享遊標變數Oracle
- v$sql_bind_capture與timestamp型別的繫結變數的數值SQLAPT型別變數
- 繫結變數的正確使用,bind peeking,Adaptive Cursor Sharing變數APT
- oracle10g_11g_繫結變數bind_與最優執行計劃explain planOracle變數AI
- 如何解決執行計劃繫結變數bind peeking重新硬解析變數
- 檢視繫結變數變數
- 繫結變數窺測變數
- PLSQL使用繫結變數SQL變數
- 關於繫結變數變數
- ORACLE通過BIND_AWARE+SQL PATCH解決SQL繫結變數中資料傾斜的問題OracleSQL變數
- Oracle獲取繫結變數的各種方法Oracle變數
- oracle 查詢未使用繫結變數的sqlOracle變數SQL
- 【優化】使用繫結變數 OR 不使用繫結變數,這不是問題!優化變數