狠狠爱成人网_日韩一级在线_国产综合自拍_亚洲精品韩国_亚洲视频导航_麻豆成人在线播放_欧美jjzz_一区在线视频观看_美脚丝袜一区二区三区在线观看_欧美91视频

當(dāng)前位置:系統(tǒng)之家 > 技術(shù)開發(fā)教程 > 詳細頁面

JDBCTM 向?qū)?基礎(chǔ)6-PreparedStatement

JDBCTM 向?qū)?基礎(chǔ)6-PreparedStatement

更新時間:2019-09-15 文章作者:未知 信息來源:網(wǎng)絡(luò) 閱讀次數(shù):

6 - PreparedStatement
本概述是從《JDBCTM Database Access from JavaTM: A Tutorial and Annotated Reference 》這本書中摘引來的。JavaSoft 目前正在準(zhǔn)備這本書。這是一本教程,同時也是 JDBC 的重要參考手冊,它將作為 Java 系列的組成部份在 1997 年春季由 Addison-Wesley 出版公司出版。


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


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

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

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


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

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

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

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

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

利用 pstmt(前面創(chuàng)建的 PreparedStatement 對象),以下代碼例示了如何設(shè)置兩個參數(shù)占位符的值并執(zhí)行 pstmt 10 次。如上所述,為做到這一點,數(shù)據(jù)庫不能關(guān)閉 pstmt。在該示例中,第一個參數(shù)被設(shè)置為 "Hi"并保持為常數(shù)。在 for 循環(huán)中,每次都將第二個參數(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 類型),因為驅(qū)動程序?qū)?Java 類型映射為相應(yīng)的 JDBC 類型(遵循該 JDBC Guide中§8.6.2 “映射 Java 和 JDBC 類型”表中所指定的映射),并將該 JDBC 類型發(fā)送給數(shù)據(jù)庫。例如,以下代碼段將 PreparedStatement 對象 pstmt 的第二個參數(shù)設(shè)置為 44,Java 類型為 short:

pstmt.setShort(2, 44);

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

程序員的責(zé)任是確保將每個 IN 參數(shù)的 Java 類型映射為與數(shù)據(jù)庫所需的 JDBC 數(shù)據(jù)類型兼容的 JDBC 類型。不妨考慮數(shù)據(jù)庫需要 JDBC SMALLINT 的情況。如果使用方法 setByte ,則驅(qū)動程序?qū)?JDBC TINYINT 發(fā)送給數(shù)據(jù)庫。這是可行的,因為許多數(shù)據(jù)庫可從一種相關(guān)的類型轉(zhuǎn)換為另一種類型,并且通常 TINYINT 可用于 SMALLINT 適用的任何地方。然而,對于要適用于盡可能多的數(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 類型。該方法可以接受第三個參數(shù),用來指定目標(biāo) JDBC 類型。將 Java Object 發(fā)送給數(shù)據(jù)庫之前,驅(qū)動程序?qū)阉D(zhuǎn)換為指定的 JDBC 類型。

如果沒有指定 JDBC 類型,驅(qū)動程序就會將 Java Object 映射到其缺省的 JDBC 類型(參見第 8.6.4 節(jié)中的表格),然后將它發(fā)送到數(shù)據(jù)庫。這與常規(guī)的 setXXX 方法類似;在這兩種情況下,驅(qū)動程序在將值發(fā)送到數(shù)據(jù)庫之前,會將該值的 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 對象的能力使應(yīng)用程序更為通用,并可在運行時接受參數(shù)的輸入。這種情況下,應(yīng)用程序在編譯時并不清楚輸入類型。通過使用 setObject,應(yīng)用程序可接受所有 Java 對象類型作為輸入,并將其轉(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 方法時(如果它接受 Java 對象作為參數(shù)),也將同樣把 JDBC NULL 發(fā)送到數(shù)據(jù)庫。但僅當(dāng)指定 JDBC 類型時,方法 setObject 才能接受 null 值。


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

JDBC 提供了三種將 IN 參數(shù)設(shè)置為輸入流的方法:setBinaryStream 用于含有未說明字節(jié)的流, setAsciiStream 用于含有 ASCII 字符的流,而 setUnicodeStream 用于含有 Unicode 字符的流。因為必須指定流的總長度,所以這些方法所采用的參數(shù)比其它的 setXXX 方法要多一個。這很有必要,因為一些數(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í)行時,將反復(fù)調(diào)用輸入流 fin 以傳遞其數(shù)據(jù)。


溫馨提示:喜歡本站的話,請收藏一下本站!

本類教程下載

系統(tǒng)下載排行

狠狠爱成人网_日韩一级在线_国产综合自拍_亚洲精品韩国_亚洲视频导航_麻豆成人在线播放_欧美jjzz_一区在线视频观看_美脚丝袜一区二区三区在线观看_欧美91视频
欧美四级电影网| 日韩精品亚洲一区二区三区免费| 91麻豆精品国产91久久久资源速度| 久久av一区二区| 裸体素人女欧美日韩| 亚洲欧美电影在线观看| 久久久久一区二区| 欧美午夜精品久久久| 欧美精品日韩一区| 欧美一二三在线| 久久影院电视剧免费观看| 国产亚洲人成网站| 国产精品成人免费在线| 亚洲老司机在线| 视频一区二区三区在线| 精品一区二区免费看| 国产成人av福利| 91在线播放网址| 影音先锋在线一区| 久久福利毛片| 91精品国产91热久久久做人人| 欧美成人性福生活免费看| 国产欧美综合在线观看第十页| 亚洲婷婷国产精品电影人久久| 亚洲成人综合在线| 经典一区二区三区| 91视视频在线观看入口直接观看www| 伊人成人网在线看| 日本黄色一区二区| 日韩免费一区二区三区在线播放| 中文字幕精品在线不卡| 性做久久久久久久久| 韩国理伦片一区二区三区在线播放| 成人午夜电影久久影院| 亚洲高清123| 欧美美女一区二区三区| 中文字幕+乱码+中文字幕一区| 亚洲 欧美综合在线网络| 国产激情91久久精品导航| 国产综合激情| 欧美在线啊v一区| 国产三级精品三级在线专区| 亚洲国产精品一区二区久久| 国产很黄免费观看久久| 亚洲精品中文字幕在线| 91精品国产欧美一区二区成人 | 91精品国产欧美一区二区| 国产精品私人影院| 免费人成精品欧美精品| 国产精品www994| 在线看日本不卡| 中文字幕欧美日韩一区| 强制捆绑调教一区二区| 欧美人与禽猛交乱配| 日本高清不卡在线观看| 亚洲国产精品av| 国产毛片精品视频| 国产亚洲精品久久飘花| 26uuu亚洲婷婷狠狠天堂| 丝袜美腿成人在线| 国产一区二区三区无遮挡| 精品视频一区三区九区| 亚洲精品视频在线观看免费| 不卡一区二区三区四区| 欧美综合亚洲图片综合区| 国产精品女同互慰在线看| 国产精品一区二区在线播放| 亚洲影视在线| 国产精品国产自产拍高清av王其 | 精品视频资源站| 亚洲一区免费观看| 欧美午夜精彩| 欧美大片拔萝卜| 韩国av一区二区三区四区| 亚洲免费黄色| 国产精品亲子乱子伦xxxx裸| 福利一区福利二区| 欧美日韩视频在线第一区| 性做久久久久久免费观看 | 久久婷婷一区二区三区| 国内成人免费视频| 色欧美88888久久久久久影院| 亚洲精品视频免费看| 欧美日韩免费观看一区| 精品999久久久| 国产成人av电影在线观看| 欧美日韩国产免费一区二区| 日本不卡1234视频| 久久精品日韩| 午夜在线成人av| 性久久久久久| 亚洲国产一区二区视频| 国产午夜精品一区二区三区欧美| 国产精品久久久久婷婷| 欧美日韩亚洲国产精品| 欧美激情艳妇裸体舞| 95精品视频在线| 欧美精品一区视频| av高清久久久| 久久久精品国产免大香伊| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 激情综合五月天| 欧美美女一区二区在线观看| 国产精品中文有码| 日韩免费视频一区| 91蜜桃在线免费视频| 久久亚洲私人国产精品va媚药| 99视频精品全部免费在线| 久久综合狠狠综合久久综合88| 91玉足脚交白嫩脚丫在线播放| 国产欧美视频一区二区| 国内综合精品午夜久久资源| 亚洲人成在线观看一区二区| 国产精品丝袜xxxxxxx| 视频一区欧美精品| 欧美日韩亚洲综合在线 | 国产精品综合av一区二区国产馆| 91麻豆精品久久久久蜜臀| 成人福利在线看| 中文字幕一区日韩精品欧美| 亚洲欧美日本视频在线观看| 另类小说欧美激情| 精品国精品国产尤物美女| 午夜久久影院| 亚洲一区二区在线播放相泽| 在线观看av不卡| 成人国产精品免费观看视频| 最新成人av在线| 色婷婷国产精品| av不卡一区二区三区| 亚洲精品一卡二卡| 欧美三级中文字| 午夜国产精品视频| 日本色综合中文字幕| 欧美xxxxx裸体时装秀| 亚洲国产精品一区二区第四页av| 日韩av不卡在线观看| 精品捆绑美女sm三区| 亚洲激情国产| 国产乱码精品一区二区三区忘忧草| 久久精品亚洲精品国产欧美| 国产精品普通话对白| 国产成人午夜精品5599 | 9人人澡人人爽人人精品| 亚洲激情一二三区| 日韩欧美一级特黄在线播放| 一本色道久久| 国产福利91精品一区二区三区| 成人欧美一区二区三区| 在线播放欧美女士性生活| 国产精品国产一区二区| 经典三级一区二区| 中文字幕亚洲成人| 欧美嫩在线观看| 国产亚洲一区在线| 成人精品鲁一区一区二区| 亚洲高清免费视频| 久久久一区二区三区捆绑**| 色婷婷综合视频在线观看| 欧美日一区二区在线观看| 蜜臀av一区二区三区| 国产精品久久久久影院色老大| 3d动漫精品啪啪| 噜噜噜久久亚洲精品国产品小说| 欧美一区二区三区在线播放| 精品一区二区三区蜜桃| 一区二区三区欧美激情| 久久久久久久久久久久久夜| 欧美综合视频在线观看| 99精品热视频只有精品10| 不卡一区二区三区四区| 精品一区二区在线看| 一区二区视频在线| 国产亚洲欧美中文| 日韩视频免费直播| 欧美午夜精品久久久久久孕妇| 国产乱码精品| 黄色另类av| 欧美激情日韩| 不卡的av网站| 国产mv日韩mv欧美| 激情文学综合插| 人人精品人人爱| 亚洲成av人**亚洲成av**| 亚洲美女免费在线| 中文字幕制服丝袜成人av | 成人免费视频一区二区| 国产一区欧美一区| 蜜臀av性久久久久蜜臀aⅴ流畅| 亚洲伊人色欲综合网| 日韩美女视频一区二区| 国产精品久久777777| 国产欧美日韩激情| 久久久久国产免费免费| 久久久久高清精品| 久久免费精品国产久精品久久久久| 日韩视频中午一区| 日韩精品一区二区三区在线观看 | 国产精品久久久久影院| 中文字幕一区在线|