亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

JDBC 概述(六)

2019-11-18 12:40:23
字體:
來源:轉載
供稿:網友

  6 - PReparedStatement
  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 類型(遵循該 JDBCGuide中§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 以傳遞其數據。

上一篇:JDBC 概述(七)

下一篇:JDBC 概述(五)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
北条麻妃一区二区三区中文字幕| 国产精品视频久久久| 伊人久久久久久久久久久| 97人人模人人爽人人喊中文字| 欧美人与物videos| 亚洲精品美女在线观看播放| 欧美乱妇高清无乱码| 国语自产精品视频在线看抢先版图片| 亚洲成人精品av| www.国产一区| 在线精品国产欧美| www亚洲精品| 亚洲欧美日韩国产中文| 国产伊人精品在线| 日本人成精品视频在线| 国产三级精品网站| 国模吧一区二区三区| 欧美色视频日本高清在线观看| 日韩最新中文字幕电影免费看| 青青草国产精品一区二区| 97国产成人精品视频| 中文国产成人精品| 这里只有精品丝袜| 亚洲最大激情中文字幕| 精品人伦一区二区三区蜜桃网站| 正在播放国产一区| 在线视频免费一区二区| 激情亚洲一区二区三区四区| 亚洲日本欧美中文幕| 日韩精品日韩在线观看| 欧美成人精品在线观看| 亚洲欧美国产制服动漫| 欧美俄罗斯乱妇| 欧美性猛交xxxx乱大交极品| 欧美在线性爱视频| 欧美亚洲视频在线看网址| 国产91色在线播放| 成人久久一区二区三区| 国产日产亚洲精品| 国产精品ⅴa在线观看h| 久久久久久国产精品久久| 日韩乱码在线视频| 欧美一区二区影院| 黑人巨大精品欧美一区二区一视频| 亚洲xxxx在线| 亚洲欧美另类自拍| 亚洲视频免费一区| 亚洲精品久久久久久久久久久久| 久久精品国产综合| 一区二区三区精品99久久| 992tv在线成人免费观看| 欧美性xxxxx极品娇小| 欧美另类暴力丝袜| 国产噜噜噜噜久久久久久久久| 欧美久久久精品| 欧美大片va欧美在线播放| 国产极品jizzhd欧美| 日韩免费在线视频| 色在人av网站天堂精品| 精品国产欧美成人夜夜嗨| 隔壁老王国产在线精品| 亚洲经典中文字幕| 91日本视频在线| 久久伊人色综合| 亚洲免费小视频| 国产精品v片在线观看不卡| 亚洲精品色婷婷福利天堂| 欧美成人午夜激情| xxx欧美精品| 韩国视频理论视频久久| 在线播放国产一区中文字幕剧情欧美| 亚洲第一视频在线观看| 国产又爽又黄的激情精品视频| 超薄丝袜一区二区| 亚洲免费影视第一页| 欧美亚洲免费电影| 日韩国产高清视频在线| 成人免费视频a| 成人精品一区二区三区电影黑人| 午夜精品久久久久久久99热浪潮| 欧美精品午夜视频| 欧美大尺度电影在线观看| 精品一区二区三区电影| 国产日韩精品电影| 中文字幕日韩av综合精品| 91在线视频精品| 国内精品久久久久久久久| 亚洲人在线视频| 亚洲视频日韩精品| 成人有码视频在线播放| 国产精品va在线| 国产99久久精品一区二区| 日韩成人激情视频| 国产精品a久久久久久| 国产精品久久视频| 九九久久精品一区| 91久久精品国产| 国产精品激情自拍| 国产精品私拍pans大尺度在线| 欧美激情在线观看| 欧美精品18videosex性欧美| 欧美大片大片在线播放| 97成人精品区在线播放| 国产精品久久久999| 久久久伊人欧美| 亚洲精品一区二区三区婷婷月| 亚洲专区国产精品| 97视频网站入口| 成人日韩在线电影| 国产精品永久免费观看| 国产欧美一区二区三区在线看| 成人精品视频在线| 69久久夜色精品国产69乱青草| 欧美在线观看视频| 69久久夜色精品国产69乱青草| 最近中文字幕mv在线一区二区三区四区| 国产在线观看精品| 亚洲男人av在线| 日韩欧美精品在线观看| 日韩网站免费观看| 亚洲成人激情图| 亚洲国产精品电影在线观看| 午夜精品一区二区三区在线视频| 国产精品69av| 色香阁99久久精品久久久| 亚洲一区二区精品| 国产精品美腿一区在线看| 日韩欧美大尺度| 在线视频国产日韩| 国产精品日韩电影| 亚洲精品suv精品一区二区| 色99之美女主播在线视频| 日本欧美中文字幕| 欧美另类xxx| 91禁国产网站| 亚洲免费视频一区二区| 成人av电影天堂| 国产精品男女猛烈高潮激情| 亚洲一区二区三区久久| 久久久久久久亚洲精品| 日韩精品欧美激情| 国产精品精品视频一区二区三区| 亚洲国产精品推荐| 日韩影视在线观看| 色先锋久久影院av| 欧美美最猛性xxxxxx| 国产精品久久久av久久久| 亚洲国产成人精品一区二区| 欧美裸体视频网站| 成人精品视频在线| 日韩高清电影免费观看完整| 免费不卡欧美自拍视频| 亚洲欧美一区二区三区四区| 精品国产一区二区三区久久狼黑人| 久久亚洲精品一区二区| 欧美伊久线香蕉线新在线| 这里只有精品在线播放| 亚洲xxxxx电影| 亚洲精品久久在线| 69久久夜色精品国产7777| 亚洲精品网站在线播放gif| 国产成人啪精品视频免费网| 91精品久久久久久久久久久久久| 欧美老女人在线视频|