JDBC教程之PreparedStatement

weixin_33766168發表於2017-11-14
< DOCTYPE html PUBLIC -WCDTD XHTML StrictEN httpwwwworgTRxhtmlDTDxhtml-strictdtd>
     以前程式裡使用SQL訪問資料庫時,都是直接用“+”將欄位值嵌到SQL中。如:String sql  =   " select s.name from student s where s.id=' "   +  sId  +   " ' ";其實大部份資料庫讀取都可以用PreparedStatement來實現。 
     通常每個SQL語句都要通過 語法分析 -> 生成邏輯查詢計劃 -> 邏輯優化 -> 物理優化 等步驟生成具體的執行計劃,用PreparedStatement就可以生成一個執行計劃,以後只是引數改變(相當於執行計劃的執行環境改變),前面的四個步驟也會省略,從而提高了效率。
 
概述 

該 PreparedStatement 介面繼承 Statement,並與之在兩方面有所不同:

PreparedStatement 例項包含已編譯的 SQL 語句。這就是使語句“準備好”。包含於 PreparedStatement 物件中的 SQL 語句可具有一個或多個 IN 引數。IN引數的值在 SQL 語句建立時未被指定。相反的,該語句為每個 IN 引數保留一個問號(“?”)作為佔位符。每個問號的值必須在該語句執行之前,通過適當的setXXX 方法來提供。
由於 PreparedStatement 物件已預編譯過,所以其執行速度要快於 Statement 物件。因此,多次執行的 SQL 語句經常建立為 PreparedStatement 物件,以提高效率。

作為 Statement 的子類,PreparedStatement 繼承了 Statement 的所有功能。另外它還新增了一整套方法,用於設定傳送給資料庫以取代 IN 引數佔位符的值。同時,三種方法 execute、 executeQuery 和 executeUpdate 已被更改以使之不再需要引數。這些方法的 Statement 形式(接受 SQL 語句引數的形式)不應該用於 PreparedStatement 物件。

1、建立 PreparedStatement 物件

以下的程式碼段(其中 con 是 Connection 物件)建立包含帶兩個 IN 引數佔位符的 SQL 語句的 PreparedStatement 物件:

PreparedStatement pstmt = con.prepareStatement("UPDATE table4 SET m = ? WHERE x = ?");

pstmt 物件包含語句 "UPDATE table4 SET m = ? WHERE x = ?",它已傳送給DBMS,併為執行作好了準備。

2、傳遞 IN 引數

在執行 PreparedStatement 物件之前,必須設定每個 ? 引數的值。這可通過呼叫 setXXX 方法來完成,其中 XXX 是與該引數相應的型別。例如,如果引數具有Java 型別 long,則使用的方法就是 setLong。setXXX 方法的第一個引數是要設定的引數的序數位置,第二個引數是設定給該引數的值。例如,以下程式碼將第一個引數設為 123456789,第二個引數設為 100000000:

pstmt.setLong(1, 123456789);
pstmt.setLong(2, 100000000);
一旦設定了給定語句的引數值,就可用它多次執行該語句,直到呼叫clearParameters 方法清除它為止。在連線的預設模式下(啟用自動提交),當語句完成時將自動提交或還原該語句。

如果基本資料庫和驅動程式在語句提交之後仍保持這些語句的開啟狀態,則同一個 PreparedStatement 可執行多次。如果這一點不成立,那麼試圖通過使用PreparedStatement 物件代替 Statement 物件來提高效能是沒有意義的。

利用 pstmt(前面建立的 PreparedStatement 物件),以下程式碼例示瞭如何設定兩個引數佔位符的值並執行 pstmt 10 次。如上所述,為做到這一點,資料庫不能關閉 pstmt。在該示例中,第一個引數被設定為 "Hi"並保持為常數。在 for 迴圈中,每次都將第二個引數設定為不同的值:從 0 開始,到 9 結束。

pstmt.setString(1, "Hi");

當 SQL 語句將執行許多次時,您可以使用 PreparedStatement 物件。SQL 語句可以預編譯。“已準備的” 語句是已預編譯的 SQL 語句。與使用 Statement 物件多次執行同一條語句(在每次執行語句時都要對其進行編譯)相比,此方法效率更高。另外,PreparedStatement 物件中包含的 SQL 語句可能有一個或多個 IN 引數。使用 Connection.prepareStatement() 來建立 PreparedStatement 物件。

您可以使用成批更新功能來將單個 PreparedStatement 物件與多組輸入引數值相關聯。然後,可將此部件傳送至資料庫,作為單一實體進行處理。因為處理一組更新操作通常比每次處理一個更新操作要快,所以成批更新可獲得更好的效能。若要使用成批更新程式,需要 JDBC 2.0 和 JDK 1.2。

下列示例顯示如何使用 PreparedStatement 介面。

                       // Connect to the AS/400.     Connection c = DriverManager.getConnection("jdbc:as400://mySystem");                       // Create the PreparedStatement                       // object. It precompiles the                       // specified SQL statement. The                       // question marks indicate where                       // parameters must be set before the                       // statement is run.     PreparedStatement ps = c.prepareStatement("INSERT INTO MYLIBRARY.MYTABLE (NAME, ID) VALUES (?, ?)");                       // Set parameters and run the                       // statement.     ps.setString(1, "JOSH");     ps.setInt(2, 789);     ps.executeUpdate();                       // Set parameters and run the                       // statement again.     ps.setString(1, "DAVE");     ps.setInt(2, 456);     ps.executeUpdate();                       // Close PreparedStatement and the                       // Connection.     ps.close();     c.close();
本文轉自 netcorner 部落格園部落格,原文連結: http://www.cnblogs.com/netcorner/archive/2007/02/13/2912428.html ,如需轉載請自行聯絡原作者

相關文章