国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JSP > 正文

JDBCTM 指南:入門6-PreparedStatement

2020-06-01 23:27:04
字體:
來源:轉載
供稿:網友
6 - PreparedStatement
本概述是從《JDBCTM Database Access from JavaTM: A Tutorial and Annotated Reference 》這本書中摘引來的。JavaSoft 目前正在準備這本書。這是一本教程,同時也是 JDBC 的重要參考手冊,它將作為 Java 系列的組成部份在 1997 年春季由 Addison-Wesley 出版公司出版。


6.1 概述
該 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 對象。


6.1.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,并為執行作好了準備。


6.1.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 結束。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 冀州市| 呼和浩特市| 安阳县| 大姚县| 丰宁| 阳原县| 金平| 太谷县| 高阳县| 赤城县| 吉首市| 茌平县| 旬邑县| 嘉定区| 永仁县| 正安县| 阿坝| 富川| 舒兰市| 泗阳县| 会昌县| 全州县| 广昌县| 巴东县| 新建县| 瓦房店市| 长治县| 故城县| 饶平县| 二连浩特市| 闽侯县| 鹿泉市| 原平市| 南皮县| 莎车县| 建瓯市| 萝北县| 芜湖县| 青岛市| 淮南市| 禹州市|