校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

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

JDBCTM 指南:入門6-PreparedStatement

熱門標簽:廣州三五防封電銷卡 地圖標注制作道路 長春回撥外呼系統廠家 山東智能云外呼管理系統 電銷外呼系統 排行榜 地圖標注創業項目入駐 外呼系統啥意思 珠海銷售外呼系統運營商 四川電信外呼系統靠譜嗎
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 結束。

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

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

pstmt.setShort(2, 44);

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

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


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

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

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


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

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


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

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

以下代碼例示了使用流作為 IN 參數來發送文件內容:

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();

當語句執行時,將反復調用輸入流 fin 以傳遞其數據。


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

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

巨人網絡通訊聲明:本文標題《JDBCTM 指南:入門6-PreparedStatement》,本文關鍵詞  JDBCTM,指南,入門,6-PreparedStatement,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《JDBCTM 指南:入門6-PreparedStatement》相關的同類信息!
  • 本頁收集關于JDBCTM 指南:入門6-PreparedStatement的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    蜜臀av性久久久久蜜臀aⅴ四虎| 在线播放中文字幕一区| 亚洲成人7777| 1024成人网| 欧美日韩一级片在线观看| 成人午夜视频在线观看| 国产在线不卡一区| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲激情av在线| 《视频一区视频二区| 国产精品国产精品国产专区不片| 精品国产自在久精品国产| 91精品国产91久久综合桃花| 欧美综合一区二区三区| 日本电影欧美片| 一本到三区不卡视频| 99久久国产综合精品麻豆| 99久久综合狠狠综合久久| 成人性生交大片免费看中文| 成人小视频在线| 粉嫩aⅴ一区二区三区四区| 国产a视频精品免费观看| 国产美女一区二区| 成人美女视频在线观看| 成人h动漫精品一区二区| 99精品在线免费| 欧美色倩网站大全免费| 欧美美女bb生活片| 日韩网站在线看片你懂的| 日韩精品一区二区三区在线| 精品国产亚洲在线| 欧美激情一区二区三区全黄| 精品国产乱码久久久久久久久 | av中文字幕亚洲| 91美女片黄在线观看91美女| 欧美视频一区二区三区| 欧美日本高清视频在线观看| 欧美日韩色一区| 精品国产免费人成电影在线观看四季 | 欧美性高清videossexo| 欧美精品久久一区二区三区 | 午夜不卡在线视频| 日韩成人一区二区三区在线观看| 蜜桃av一区二区三区| 成人听书哪个软件好| zzijzzij亚洲日本少妇熟睡| 欧美日韩国产影片| 26uuu亚洲综合色| 亚洲男人电影天堂| 麻豆精品在线观看| 91蜜桃传媒精品久久久一区二区| 欧美美女黄视频| 中文字幕一区二区三| 亚洲午夜av在线| 国产成人免费av在线| 欧美午夜片在线看| 久久一留热品黄| 亚洲综合免费观看高清完整版| 麻豆91在线看| 99国产精品视频免费观看| 日韩一级完整毛片| 亚洲丝袜另类动漫二区| 裸体健美xxxx欧美裸体表演| 93久久精品日日躁夜夜躁欧美| 日韩欧美亚洲国产另类| 亚洲日本在线看| 国产黄人亚洲片| 91麻豆精品国产无毒不卡在线观看| 国产性做久久久久久| 日韩高清一级片| 97成人超碰视| 欧美国产亚洲另类动漫| 精品伊人久久久久7777人| 欧美丝袜丝交足nylons| 中文字幕永久在线不卡| 国产一区二区三区不卡在线观看 | 大胆欧美人体老妇| 2022国产精品视频| 一级中文字幕一区二区| 经典三级在线一区| 欧美亚洲综合在线| 久久久久久一级片| 日本不卡一二三| 在线观看区一区二| 欧美xxxxxxxxx| 亚洲一区二区综合| 丰满白嫩尤物一区二区| 精品福利一区二区三区免费视频| 国产精品蜜臀av| 免费av网站大全久久| 欧美日韩一区不卡| 亚洲最大色网站| 97成人超碰视| 亚洲人成影院在线观看| 色婷婷国产精品| 国产精品美女久久福利网站| 国产黄人亚洲片| 国产精品进线69影院| av福利精品导航| 亚洲蜜臀av乱码久久精品| 9人人澡人人爽人人精品| 欧美韩国日本不卡| 色综合天天天天做夜夜夜夜做| 亚洲免费av高清| 欧美日韩在线播放三区四区| 天使萌一区二区三区免费观看| 51精品国自产在线| 狠狠色丁香婷综合久久| 久久久不卡网国产精品一区| 国产精品一区二区男女羞羞无遮挡| 日本一区二区三区电影| 成人av动漫网站| 亚洲激情图片qvod| 日韩视频免费观看高清完整版 | 日韩欧美www| 处破女av一区二区| 亚洲毛片av在线| 制服丝袜在线91| 国产一区二区三区在线观看免费| 日本一区二区三区dvd视频在线| 不卡视频一二三| 天天综合网 天天综合色| 精品国产乱码久久久久久蜜臀| 成人福利电影精品一区二区在线观看| 综合婷婷亚洲小说| 91精品国产综合久久久久久| 国产成人免费视频网站| 亚洲精品国产精品乱码不99| 日韩欧美在线网站| eeuss影院一区二区三区| 亚洲bt欧美bt精品| 国产精品久久久久久久久免费丝袜 | 国产精品网站导航| 91网站黄www| 亚洲国产wwwccc36天堂| 日韩欧美专区在线| 国产黑丝在线一区二区三区| 亚洲激情图片一区| 国产三级一区二区三区| 欧美亚洲自拍偷拍| 懂色一区二区三区免费观看| 日精品一区二区三区| 日韩一区欧美小说| 日韩一级二级三级| 欧美主播一区二区三区美女| 懂色av中文一区二区三区| 日本成人在线视频网站| 亚洲精品视频在线看| 亚洲国产精品ⅴa在线观看| 日韩精品中文字幕一区二区三区| 99久久精品国产毛片| 国产精品一级在线| 秋霞午夜av一区二区三区| 一区二区激情小说| 1区2区3区国产精品| 中文字幕乱码一区二区免费| 欧美电影免费观看高清完整版在线 | 一区二区三区四区精品在线视频| 久久综合久久久久88| 91精品国产综合久久国产大片| 91免费视频观看| 91色|porny| 色伊人久久综合中文字幕| 99久久久免费精品国产一区二区| 国产精品一区二区无线| 极品少妇一区二区| 韩日精品视频一区| 另类综合日韩欧美亚洲| 久久精工是国产品牌吗| 青青草97国产精品免费观看| 午夜久久福利影院| 视频一区在线播放| 视频一区在线播放| 日av在线不卡| 久久99精品网久久| 国产在线不卡一卡二卡三卡四卡| 久久精品99国产国产精| 国产一区欧美日韩| 国产馆精品极品| 不卡视频在线观看| 日本乱码高清不卡字幕| 欧美日韩亚洲综合在线 欧美亚洲特黄一级 | 亚洲国产精品v| 国产精品国产三级国产aⅴ中文 | 精品成人一区二区三区四区| 国产欧美日韩在线看| 亚州成人在线电影| 国产91丝袜在线播放0| 欧美性三三影院| 久久久不卡网国产精品二区| 一区二区三区精品久久久| 蜜桃在线一区二区三区| 一本一道久久a久久精品| 在线91免费看| 国产精品盗摄一区二区三区| 狠狠色丁香婷综合久久| 欧美中文字幕一区二区三区亚洲| 久久综合九色综合欧美亚洲| 天涯成人国产亚洲精品一区av| 99热国产精品|