寶貝小豬嘜

          常用鏈接

          統(tǒng)計

          最新評論

          JDBC基礎(chǔ)教程之PreparedStatement

          該 PreparedStatement 接口繼承 Statement,并與之在兩方面有所不同:
          PreparedStatement 實例包含已編譯的 SQL 語句。這就是使語句“準(zhǔn)備好”。包含于 PreparedStatement 對象中的 SQL 語句可具有一個或多個 IN 參數(shù)。IN參數(shù)的值在 SQL 語句創(chuàng)建時未被指定。相反的,該語句為每個 IN 參數(shù)保留一個問號(“?”)作為占位符。每個問號的值必須在該語句執(zhí)行之前,通過適當(dāng)?shù)膕etXXX 方法來提供。
          由于 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 對象。
          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)備。

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

            3、IN 參數(shù)中數(shù)據(jù)類型的一致性

            setXXX 方法中的 XXX 是 Java 類型。它是一種隱含的 JDBC 類型(一般 SQL 類型),因為驅(qū)動程序?qū)?Java 類型映射為相應(yīng)的 JDBC 類型(遵循該 JDBCGuide中§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 適用的任何地方

          posted on 2006-12-05 16:04 寶貝小豬嘜 閱讀(130) 評論(0)  編輯  收藏 所屬分類: 數(shù)據(jù)庫相關(guān)


          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 大同县| 互助| 交城县| 利辛县| 巨鹿县| 姚安县| 泰来县| 安宁市| 中卫市| 建湖县| 饶平县| 鄯善县| 阜新| 收藏| 巢湖市| 锦州市| 永康市| 颍上县| 兴化市| 赞皇县| 琼中| 康马县| 罗田县| 苏尼特左旗| 林周县| 石门县| 佳木斯市| 乌拉特前旗| 稷山县| 屯昌县| 商河县| 江达县| 江山市| 册亨县| 南平市| 兴山县| 富平县| 吉木萨尔县| 保康县| 冷水江市| 精河县|