動態sql與靜態sql的區別


首先,所謂SQL的動態和靜態,是指SQL語句在何時被編譯和執行,二者都是用在SQL嵌入式編程中的,這里所說的嵌入式是指將SQL語句嵌入在高級語言中,而不是針對於單片機的那種嵌入式編程。

靜態SQL,在編譯階段就可以確定數據庫要做什么事情。在某種高級語言中,如果嵌入了SQL語句,而這個SQL語句的主體結構已經明確,

例如在Java的一段代碼中有一個待執行的SQL“select * from t1 where c1>5”,在Java編譯階段,就可以將這段SQL交給數據庫管理系統去分析,數據庫軟件可以對這段SQL進行語法解析,生成數據庫方面的可執行代碼,這樣的SQL稱為靜態SQL。


動態SQL,而如果嵌入的SQL沒有明確給出,如在Java中定義了一個字符串類型的變量sql:String sql;,然后采用preparedStatement對象的execute方法去執行這個sql,該sql的值可能等於從文本框中讀取的一個SQL或者從鍵盤輸入的SQL,但具體是什么,在編譯時無法確定,只有等到程序運行起來,在執行的過程中才能確定,這種SQL叫做動態SQL。

例如每一種數據庫軟件都有能夠執行SQL語句的界面,那個界面接收的SQL就是動態SQL,因為數據庫廠商在做這個界面時,並不知道用戶會輸入哪些SQL,只有在該界面執行后,接收了用戶的實際輸入,才知道SQL是什么。

另外還要注意一點,在SQL中如果某些參數沒有確定,如"select * from t1 where c1>? and c2<?",這種語句是靜態SQL,不是動態SQL,雖然個別參數的值不知道,但整個SQL的結構已經確定,數據庫是可以將它編譯的,在執行階段只需將個別參數的值補充進來即可。

轉載於:https://www.cnblogs.com/FengzZ/p/4890045.html

 

SQL 語句從編譯和運行的角度可以分為兩種,靜態 SQL和 動態 SQL,這兩種 SQL 在使用方式、運行機制和性能表現等方面各有特點 :

靜態 SQL:靜態 SQL 語句一般用於嵌入式 SQL 應用中,在程序運行前,SQL 語句必須是確定的,例如 SQL 語句中涉及的列名和表名必須是存在的。靜態 SQL 語句的編譯是在應用程序運行前進行的,編譯的結果會存儲在數據庫內部。而后程序運行時,數據庫將直接執行編譯好的 SQL 語句,降低運行時的開銷。

 

動態 SQL:動態 SQL 語句是在應用程序運行時被編譯和執行的,例如,使用 DB2 的交互式工具 CLP 訪問數據庫時,用戶輸入的 SQL 語句是不確定的,因此 SQL 語句只能被動態地編譯。動態 SQL 的應用較多,常見的 CLI 和 JDBC 應用程序都使用動態 SQL。

 

靜態sql:語句類型在編程時候必須是確定好的。比如

select  from  employee  where  empno= 'abc'
select  from  employee  where  empno= '12'

都必須是確定的,唯一可以變化的是abc的值。

動態sql:語句類型可以在運行期間指定,比如clp就是最典型的動態sql程序,你可以輸入任何命令。

靜態sql的存取路徑是在運行前就確定好的,而動態sql的存取路徑是在運行時動態生成的。因此生成的存取計划相對更優,但考慮到生成存取路徑的開銷,有可能應用程序的運行時間相對會比靜態sql長些。

 

更多請參見:de.cel.blog.163.com/blog/static/514512362011423113913592/


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM