婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > JDBCTM 指南:入門6-PreparedStatement

JDBCTM 指南:入門6-PreparedStatement

熱門標簽:廣州三五防封電銷卡 地圖標注制作道路 長春回撥外呼系統(tǒng)廠家 山東智能云外呼管理系統(tǒng) 電銷外呼系統(tǒng) 排行榜 地圖標注創(chuàng)業(yè)項目入駐 外呼系統(tǒng)啥意思 珠海銷售外呼系統(tǒng)運營商 四川電信外呼系統(tǒng)靠譜嗎
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 參數(shù)。IN 參數(shù)的值在 SQL 語句創(chuàng)建時未被指定。相反的,該語句為每個 IN 參數(shù)保留一個問號(“?”)作為占位符。每個問號的值必須在該語句執(zhí)行之前,通過適當?shù)?setXXX 方法來提供。

由于 PreparedStatement 對象已預編譯過,所以其執(zhí)行速度要快于 Statement 對象。因此,多次執(zhí)行的 SQL 語句經常創(chuàng)建為 PreparedStatement 對象,以提高效率。

作為 Statement 的子類,PreparedStatement 繼承了 Statement 的所有功能。另外它還添加了一整套方法,用于設置發(fā)送給數(shù)據(jù)庫以取代 IN 參數(shù)占位符的值。同時,三種方法 execute、 executeQuery 和 executeUpdate 已被更改以使之不再需要參數(shù)。這些方法的 Statement 形式(接受 SQL 語句參數(shù)的形式)不應該用于 PreparedStatement 對象。


6.1.1 創(chuàng)建 PreparedStatement 對象
以下的代碼段(其中 con 是 Connection 對象)創(chuàng)建包含帶兩個 IN 參數(shù)占位符的 SQL 語句的 PreparedStatement 對象:

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

pstmt 對象包含語句 "UPDATE table4 SET m = ? WHERE x = ?",它已發(fā)送給 DBMS,并為執(zhí)行作好了準備。


6.1.2 傳遞 IN 參數(shù)
在執(zhí)行 PreparedStatement 對象之前,必須設置每個 ? 參數(shù)的值。這可通過調用 setXXX 方法來完成,其中 XXX 是與該參數(shù)相應的類型。例如,如果參數(shù)具有 Java 類型 long,則使用的方法就是 setLong。setXXX 方法的第一個參數(shù)是要設置的參數(shù)的序數(shù)位置,第二個參數(shù)是設置給該參數(shù)的值。例如,以下代碼將第一個參數(shù)設為 123456789,第二個參數(shù)設為 100000000:

pstmt.setLong(1, 123456789);
pstmt.setLong(2, 100000000);

一旦設置了給定語句的參數(shù)值,就可用它多次執(zhí)行該語句,直到調用 clearParameters 方法清除它為止。

在連接的缺省模式下(啟用自動提交),當語句完成時將自動提交或還原該語句。

如果基本數(shù)據(jù)庫和驅動程序在語句提交之后仍保持這些語句的打開狀態(tài),則同一個 PreparedStatement 可執(zhí)行多次。如果這一點不成立,那么試圖通過使用 PreparedStatement 對象代替 Statement 對象來提高性能是沒有意義的。

利用 pstmt(前面創(chuàng)建的 PreparedStatement 對象),以下代碼例示了如何設置兩個參數(shù)占位符的值并執(zhí)行 pstmt 10 次。如上所述,為做到這一點,數(shù)據(jù)庫不能關閉 pstmt。在該示例中,第一個參數(shù)被設置為 "Hi"并保持為常數(shù)。在 for 循環(huán)中,每次都將第二個參數(shù)設置為不同的值:從 0 開始,到 9 結束。

pstmt.setString(1, "Hi");
for (int i = 0; i 10; i++) {
pstmt.setInt(2, i);
int rowCount = pstmt.executeUpdate();
}

6.1.3 IN 參數(shù)中數(shù)據(jù)類型的一致性
setXXX 方法中的 XXX 是 Java 類型。它是一種隱含的 JDBC 類型(一般 SQL 類型),因為驅動程序將把 Java 類型映射為相應的 JDBC 類型(遵循該 JDBC Guide中§8.6.2 “映射 Java 和 JDBC 類型”表中所指定的映射),并將該 JDBC 類型發(fā)送給數(shù)據(jù)庫。例如,以下代碼段將 PreparedStatement 對象 pstmt 的第二個參數(shù)設置為 44,Java 類型為 short:

pstmt.setShort(2, 44);

驅動程序將 44 作為 JDBC SMALLINT 發(fā)送給數(shù)據(jù)庫,它是 Java short 類型的標準映射。

程序員的責任是確保將每個 IN 參數(shù)的 Java 類型映射為與數(shù)據(jù)庫所需的 JDBC 數(shù)據(jù)類型兼容的 JDBC 類型。不妨考慮數(shù)據(jù)庫需要 JDBC SMALLINT 的情況。如果使用方法 setByte ,則驅動程序將 JDBC TINYINT 發(fā)送給數(shù)據(jù)庫。這是可行的,因為許多數(shù)據(jù)庫可從一種相關的類型轉換為另一種類型,并且通常 TINYINT 可用于 SMALLINT 適用的任何地方。然而,對于要適用于盡可能多的數(shù)據(jù)庫的應用程序,最好使用與數(shù)據(jù)庫所需的確切的 JDBC 類型相應的 Java 類型。如果所需的 JDBC 類型是 SMALLINT,則使用 setShort 代替 setByte 將使應用程序的可移植性更好。


6.1.4 使用 setObject
程序員可使用 setObject 方法顯式地將輸入參數(shù)轉換為特定的 JDBC 類型。該方法可以接受第三個參數(shù),用來指定目標 JDBC 類型。將 Java Object 發(fā)送給數(shù)據(jù)庫之前,驅動程序將把它轉換為指定的 JDBC 類型。

如果沒有指定 JDBC 類型,驅動程序就會將 Java Object 映射到其缺省的 JDBC 類型(參見第 8.6.4 節(jié)中的表格),然后將它發(fā)送到數(shù)據(jù)庫。這與常規(guī)的 setXXX 方法類似;在這兩種情況下,驅動程序在將值發(fā)送到數(shù)據(jù)庫之前,會將該值的 Java 類型映射為適當?shù)?JDBC 類型。二者的差別在于 setXXX 方法使用從 Java 類型到 JDBC 類型的標準映射(參見第 8.6.2 節(jié)中的表格),而 setObject 方法使用從 Java Object 類型到 JDBC 類型的映射(參見第 8.6.4 節(jié)中的表格)。

方法 setObject 允許接受所有 Java 對象的能力使應用程序更為通用,并可在運行時接受參數(shù)的輸入。這種情況下,應用程序在編譯時并不清楚輸入類型。通過使用 setObject,應用程序可接受所有 Java 對象類型作為輸入,并將其轉換為數(shù)據(jù)庫所需的 JDBC 類型。第 8.6.5 節(jié)中的表格顯示了 setObject 可執(zhí)行的所有可能轉換。


6.1.5 將 JDBC NULL 作為 IN 參數(shù)發(fā)送
setNull 方法允許程序員將 JDBC NULL 值作為 IN 參數(shù)發(fā)送給數(shù)據(jù)庫。但要注意,仍然必須指定參數(shù)的 JDBC 類型。

當把 Java null 值傳遞給 setXXX 方法時(如果它接受 Java 對象作為參數(shù)),也將同樣把 JDBC NULL 發(fā)送到數(shù)據(jù)庫。但僅當指定 JDBC 類型時,方法 setObject 才能接受 null 值。


6.1.6 發(fā)送大的 IN 參數(shù)
setBytes 和 setString 方法能夠發(fā)送無限量的數(shù)據(jù)。但是,有時程序員更喜歡用較小的塊傳遞大型的數(shù)據(jù)。這可通過將 IN 參數(shù)設置為 Java 輸入流來完成。當語句執(zhí)行時,JDBC 驅動程序將重復調用該輸入流,讀取其內容并將它們當作實際參數(shù)數(shù)據(jù)傳輸。

JDBC 提供了三種將 IN 參數(shù)設置為輸入流的方法:setBinaryStream 用于含有未說明字節(jié)的流, setAsciiStream 用于含有 ASCII 字符的流,而 setUnicodeStream 用于含有 Unicode 字符的流。因為必須指定流的總長度,所以這些方法所采用的參數(shù)比其它的 setXXX 方法要多一個。這很有必要,因為一些數(shù)據(jù)庫在發(fā)送數(shù)據(jù)之前需要知道其總的傳送大小。

以下代碼例示了使用流作為 IN 參數(shù)來發(fā)送文件內容:

java.io.File file = new java.io.File("/tmp/data");
int fileLength = file.length();
java.io.InputStream fin = new java.io.FileInputStream(file);
java.sql.PreparedStatement pstmt = con.prepareStatement(
"UPDATE Table5 SET stuff = ? WHERE index = 4");
pstmt.setBinaryStream (1, fin, fileLength);
pstmt.executeUpdate();

當語句執(zhí)行時,將反復調用輸入流 fin 以傳遞其數(shù)據(jù)。


您可能感興趣的文章:
  • 詳解Java的JDBC中Statement與PreparedStatement對象
  • JDBC之PreparedStatement類中預編譯的綜合應用解析
  • Oracle JDBC連接BUG解決方案
  • JDBC查詢Map轉對象實現(xiàn)過程詳解
  • jdbc實現(xiàn)寵物商店管理系統(tǒng)
  • Jmeter基于JDBC請求實現(xiàn)MySQL數(shù)據(jù)庫測試
  • Java如果通過jdbc操作連接oracle數(shù)據(jù)庫
  • JDBC PreparedStatement Like參數(shù)報錯解決方案

標簽:紹興 保定 廣元 肇慶 吳忠 玉樹 北海 潮州

巨人網絡通訊聲明:本文標題《JDBCTM 指南:入門6-PreparedStatement》,本文關鍵詞  JDBCTM,指南,入門,6-PreparedStatement,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《JDBCTM 指南:入門6-PreparedStatement》相關的同類信息!
  • 本頁收集關于JDBCTM 指南:入門6-PreparedStatement的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 黄龙县| 凤山市| 晴隆县| 汉中市| 板桥市| 铜鼓县| 闻喜县| 安康市| 济宁市| 娱乐| 泗水县| 邵阳县| 鄱阳县| 泰来县| 淳化县| 阜新| 专栏| 若尔盖县| 大安市| 徐汇区| 儋州市| 哈尔滨市| 仙居县| 隆安县| 洞口县| 长春市| 酒泉市| 思南县| 白河县| 梧州市| 建昌县| 平定县| 杭州市| 九江县| 蒙山县| 普兰县| 文安县| 托克逊县| 兴海县| 周宁县| 涪陵区|