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

主頁 > 知識(shí)庫 > JDBCTM 指南:入門6-PreparedStatement

JDBCTM 指南:入門6-PreparedStatement

熱門標(biāo)簽:廣州三五防封電銷卡 地圖標(biāo)注制作道路 長(zhǎng)春回?fù)芡夂粝到y(tǒng)廠家 山東智能云外呼管理系統(tǒng) 電銷外呼系統(tǒng) 排行榜 地圖標(biāo)注創(chuàng)業(yè)項(xiàng)目入駐 外呼系統(tǒng)啥意思 珠海銷售外呼系統(tǒng)運(yùn)營商 四川電信外呼系統(tǒng)靠譜嗎
6 - PreparedStatement
本概述是從《JDBCTM Database Access from JavaTM: A Tutorial and Annotated Reference 》這本書中摘引來的。JavaSoft 目前正在準(zhǔn)備這本書。這是一本教程,同時(shí)也是 JDBC 的重要參考手冊(cè),它將作為 Java 系列的組成部份在 1997 年春季由 Addison-Wesley 出版公司出版。


6.1 概述
該 PreparedStatement 接口繼承 Statement,并與之在兩方面有所不同:


PreparedStatement 實(shí)例包含已編譯的 SQL 語句。這就是使語句“準(zhǔn)備好”。
包含于 PreparedStatement 對(duì)象中的 SQL 語句可具有一個(gè)或多個(gè) IN 參數(shù)。IN 參數(shù)的值在 SQL 語句創(chuàng)建時(shí)未被指定。相反的,該語句為每個(gè) IN 參數(shù)保留一個(gè)問號(hào)(“?”)作為占位符。每個(gè)問號(hào)的值必須在該語句執(zhí)行之前,通過適當(dāng)?shù)?setXXX 方法來提供。

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

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


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

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

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


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

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

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

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

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

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

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 類型),因?yàn)轵?qū)動(dòng)程序?qū)?Java 類型映射為相應(yīng)的 JDBC 類型(遵循該 JDBC Guide中§8.6.2 “映射 Java 和 JDBC 類型”表中所指定的映射),并將該 JDBC 類型發(fā)送給數(shù)據(jù)庫。例如,以下代碼段將 PreparedStatement 對(duì)象 pstmt 的第二個(gè)參數(shù)設(shè)置為 44,Java 類型為 short:

pstmt.setShort(2, 44);

驅(qū)動(dòng)程序?qū)?44 作為 JDBC SMALLINT 發(fā)送給數(shù)據(jù)庫,它是 Java short 類型的標(biāo)準(zhǔn)映射。

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


6.1.4 使用 setObject
程序員可使用 setObject 方法顯式地將輸入?yún)?shù)轉(zhuǎn)換為特定的 JDBC 類型。該方法可以接受第三個(gè)參數(shù),用來指定目標(biāo) JDBC 類型。將 Java Object 發(fā)送給數(shù)據(jù)庫之前,驅(qū)動(dòng)程序?qū)阉D(zhuǎn)換為指定的 JDBC 類型。

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

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


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

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


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

JDBC 提供了三種將 IN 參數(shù)設(shè)置為輸入流的方法:setBinaryStream 用于含有未說明字節(jié)的流, setAsciiStream 用于含有 ASCII 字符的流,而 setUnicodeStream 用于含有 Unicode 字符的流。因?yàn)楸仨氈付鞯目傞L(zhǎng)度,所以這些方法所采用的參數(shù)比其它的 setXXX 方法要多一個(gè)。這很有必要,因?yàn)橐恍?shù)據(jù)庫在發(fā)送數(shù)據(jù)之前需要知道其總的傳送大小。

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

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

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


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

標(biāo)簽:紹興 保定 廣元 肇慶 吳忠 玉樹 北海 潮州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《JDBCTM 指南:入門6-PreparedStatement》,本文關(guān)鍵詞  JDBCTM,指南,入門,6-PreparedStatement,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《JDBCTM 指南:入門6-PreparedStatement》相關(guān)的同類信息!
  • 本頁收集關(guān)于JDBCTM 指南:入門6-PreparedStatement的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    精品一区二区日韩| av欧美精品.com| 色婷婷久久99综合精品jk白丝| 欧美激情一区二区三区不卡 | 精品美女被调教视频大全网站| 日韩电影在线一区二区三区| 日韩视频一区二区在线观看| 国产一区二区三区视频在线播放| 欧美国产精品一区二区| 色综合中文字幕国产 | 天堂成人国产精品一区| 69堂亚洲精品首页| 国产中文一区二区三区| 中文欧美字幕免费| 91国偷自产一区二区开放时间 | 一本色道a无线码一区v| 亚洲第四色夜色| 欧美成人性战久久| 成人av网站在线| 婷婷中文字幕一区三区| 久久久久久久电影| 色狠狠综合天天综合综合| 日韩成人av影视| 国产欧美精品区一区二区三区 | 91精品婷婷国产综合久久| 国产在线麻豆精品观看| 亚洲男同性恋视频| 欧美成人三级电影在线| 91影视在线播放| 免费三级欧美电影| 亚洲欧美色图小说| 精品国产一区二区三区不卡| 色94色欧美sute亚洲线路二| 国内精品久久久久影院一蜜桃| 亚洲欧美视频在线观看视频| 久久尤物电影视频在线观看| 欧美性大战久久久久久久蜜臀 | 国产美女精品一区二区三区| 亚洲一区二区三区四区在线免费观看 | 看电影不卡的网站| 亚洲人成网站影音先锋播放| 日韩一区二区三区免费观看| 99re这里都是精品| 久久精品99国产精品| 亚洲在线观看免费| 国产精品视频九色porn| 91麻豆精品国产91久久久使用方法 | 一本大道综合伊人精品热热| 国产一区二区导航在线播放| 日韩成人免费电影| 亚洲午夜激情av| 亚洲视频一区在线| 国产午夜精品理论片a级大结局| 欧美日韩一区小说| 91国在线观看| 91丨九色丨尤物| 成人国产视频在线观看| 国产一区二区不卡| 激情伊人五月天久久综合| 日韩二区三区在线观看| 亚洲成人午夜影院| 亚洲尤物视频在线| 樱花影视一区二区| 亚洲激情自拍视频| 亚洲欧美一区二区三区国产精品| 国产精品成人在线观看| 中文文精品字幕一区二区| 久久精品网站免费观看| 久久人人爽人人爽| 国产视频一区二区三区在线观看 | 国产清纯在线一区二区www| 欧美xfplay| 欧美不卡一区二区三区| 日韩视频在线观看一区二区| 欧美一级高清片| 日韩一二三四区| 精品奇米国产一区二区三区| 精品卡一卡二卡三卡四在线| 2014亚洲片线观看视频免费| 久久综合资源网| 国产日韩精品一区二区三区| 亚洲国产精品99久久久久久久久| 欧美韩国一区二区| 日韩毛片在线免费观看| 亚洲免费高清视频在线| 亚洲午夜久久久久久久久久久| 亚洲aaa精品| 日本成人在线一区| 国产一区二区三区综合| 成人黄色一级视频| 色婷婷狠狠综合| 制服丝袜亚洲色图| 久久婷婷国产综合精品青草| 国产精品水嫩水嫩| 一级精品视频在线观看宜春院 | 国产精品私人影院| 亚洲欧洲另类国产综合| 亚洲精品中文字幕乱码三区| 五月天国产精品| 精品一区二区影视| 97久久精品人人澡人人爽| 欧美群妇大交群的观看方式| 精品国产99国产精品| 亚洲欧洲一区二区三区| 三级欧美在线一区| 国产一区二区三区免费播放| 91免费版在线| 精品日韩99亚洲| 亚洲精品福利视频网站| 韩日av一区二区| 欧美亚男人的天堂| 久久亚洲私人国产精品va媚药| 中文字幕中文字幕一区二区| 日日噜噜夜夜狠狠视频欧美人| 国精产品一区一区三区mba视频| 91麻豆.com| 久久嫩草精品久久久精品| 亚洲欧美另类小说| 国产在线播放一区三区四| 欧美最猛性xxxxx直播| 久久一夜天堂av一区二区三区| 亚洲一区二区在线免费看| 激情小说欧美图片| 欧美精品久久一区| 亚洲色图色小说| 国产一区二区三区精品视频| 欧美日韩免费视频| 亚洲欧洲99久久| 国产成人综合在线观看| 日韩一区二区三区视频在线| 亚洲精品高清视频在线观看| 成人综合在线网站| 精品国产一区二区三区忘忧草| 亚洲一区二区三区不卡国产欧美| 国产成人aaa| 精品国产99国产精品| 欧美电视剧在线观看完整版| 国产精品日韩成人| 美女视频网站黄色亚洲| 97精品久久久午夜一区二区三区| 精品国产凹凸成av人网站| 亚洲综合在线五月| av成人免费在线观看| 久久理论电影网| 免费成人在线视频观看| 欧美日本一区二区在线观看| 亚洲综合成人网| 91麻豆国产精品久久| 中文字幕免费在线观看视频一区| 久久99精品久久久| 欧美一二三在线| 日本va欧美va精品发布| 欧美精品少妇一区二区三区| 亚洲一卡二卡三卡四卡| 91久久久免费一区二区| 自拍偷拍亚洲激情| 99久久综合精品| 中文字幕人成不卡一区| av一本久道久久综合久久鬼色| 国产三级精品视频| 成人晚上爱看视频| 中文字幕一区二区三区蜜月| 成熟亚洲日本毛茸茸凸凹| 国产精品久久久久毛片软件| 成人黄色小视频| 亚洲乱码一区二区三区在线观看| 91丨九色丨国产丨porny| 亚洲九九爱视频| 欧美日韩不卡一区| 美日韩一区二区三区| 久久综合av免费| 成人午夜电影久久影院| 亚洲色图制服丝袜| 欧美日韩中文字幕精品| 青娱乐精品视频| 久久日一线二线三线suv| 成人免费视频免费观看| 亚洲精品视频自拍| 欧美精品在线一区二区三区| 蜜臀av一区二区三区| 国产日韩欧美在线一区| 91日韩在线专区| 亚洲成av人影院在线观看网| 日韩你懂的在线观看| 国产精品一区免费在线观看| 国产精品久久久久久久久久免费看| 99精品欧美一区二区三区综合在线| 亚洲国产综合视频在线观看| 日韩限制级电影在线观看| 韩国成人福利片在线播放| 国产精品成人免费在线| 欧美日韩中文国产| 国产大陆精品国产| 亚洲国产三级在线| 久久久久久免费| 在线亚洲高清视频| 国产一区二区三区精品视频| 亚洲精品欧美激情| 精品卡一卡二卡三卡四在线| 色综合久久久久综合99|