English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

JDBC 更新結果セットの例

以下は、Result Setのチュートリアルで説明されているResultSet.CONCUR_UPDATABLEおよびResultSet.TYPE_SCROLL_INSENSITIVEサンプル。このサンプルでは、テーブルに対するINSERT、UPDATE、DELETE操作を説明します。

注:処理しているテーブルは、主キーが正しく設定されている必要があります。

このサンプルコードは、前の章で説明した環境とデータベースの設定に基づいて書かれています。

以下の例をJDBCExample.javaにコピー&ペーストして、以下のようにコンパイルおよび実行してください:

//ステップ1.必要なソフトウェアパッケージをインポート
import java.sql.*;
public class JDBCExample {
   // JDBCドライバー名とデータベースURL
   static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";  
   static final String DB_URL = "jdbc:mysql://localhost/EMP";
   //  データベースの証明書
   static final String USER = "username";
   static final String PASS = "password";
   
 public static void main(String[] args) {
   Connection conn = null;
   try{
      //ステップ2:JDBCドライバーを登録
      Class.forName("com.mysql.jdbc.Driver");
      //ステップ3:接続を確立
      System.out.println("データベースに接続しています...");
      conn = DriverManager.getConnection(DB_URL,USER,PASS);
      //ステップ4:クエリを実行してステートメントを作成
      // RS例の必要なパラメータ。
      System.out.println("ステートメントの作成中...");
      Statement stmt = conn.createStatement(
                           ResultSet.TYPE_SCROLL_INSENSITIVE,
                           ResultSet.CONCUR_UPDATABLE);
     //ステップ5:クエリを実行
      String sql = "SELECT id, first, last, age FROM Employees";
      ResultSet rs = stmt.executeQuery(sql);
      System.out.println("リファレンス用のリスト結果セットを表示...");
      printRs(rs);
      //ステップ6:結果セットを巡回し、増加5の年齢
      //whileループが正常に動作するようにBFR位置に移動
      rs.beforeFirst();
      //ステップ7:結果セットからデータを抽出
      while(rs.next()){
         //列名で検索
         int newAge = rs.getInt("age") + 5;
         rs.updateDouble( "age", newAge );
         rs.updateRow();
      }
      System.out.println("リスト結果セットが新しい年齢を表示しています...");
      printRs(rs);
      // 表中にレコードを挿入します。
      //updateXXX()を使用して行を挿入し、列データを追加するために移動
      System.out.println("新しいレコードを挿入しています...");
      rs.moveToInsertRow();
      rs.updateInt("id",104);
      rs.updateString("first","John");
      rs.updateString("last","Paul");
      rs.updateInt("age",40);
      //行を提出
      rs.insertRow();
      System.out.println("リスト結果セットが新しいセットを表示しています...");
      printRs(rs);
      
      // テーブルから第二条のレコードを削除。
      // まず第二条のレコードの位置に設定
      rs.absolute( 2 );
      削除前のレコードをリストアップ...
      //列名で検索
      int id  = rs.getInt("id");
      int age = rs.getInt("age");
      String first = rs.getString("first");
      String last = rs.getString("last");
      //値を表示
      System.out.print("ID: " + id);
      System.out.print(", Age: " + age);
      System.out.print(", First: " + first);
      System.out.println(", Last: " + last);
     //行を削除
      rs.deleteRow();
      System.out.println("削除後のリザルトセットをリストアップ\
                一つのレコードを削除...
      printRs(rs);
      //ステップ8:環境をクリーンアップ
      rs.close();
      stmt.close();
      conn.close();
   }catch(SQLException se){
      //JDBCエラーを処理
      se.printStackTrace();
   }catch(Exception e){
      //Class.forNameのエラーを処理
      e.printStackTrace();
   }finally{
      //リソースを閉じるための
      try{
         if(conn!=null)
            conn.close();
      }catch(SQLException se){
         se.printStackTrace();
      }
   }
   System.out.println("Goodbye!");
}//mainを終了
   public static void printRs(ResultSet rs) throws SQLException{
      //最初の行から始めることを確認
      rs.beforeFirst();
      while(rs.next()){
         //列名で検索
         int id  = rs.getInt("id");
         int age = rs.getInt("age");
         String first = rs.getString("first");
         String last = rs.getString("last");
         //値を表示
         System.out.print("ID: " + id);
         System.out.print(", Age: " + age);
         System.out.print(", First: " + first);
         System.out.println(", Last: " + last);
     }
     System.out.println();
   }//printRs()を終了
}//JDBCExampleを終了

今、上記の例をコンパイルしてみましょう。

C:\>javac JDBCExample.java
C:\>

実行時JDBCExample、以下のような結果が生成されます-

C:\>java JDBCExample
データベースに接続しています...
ステートメントの作成...
リファレンス用のリザルトセットをリストに...
ID: 100, Age: 33, First: Zara, Last: Ali
ID: 101, Age: 40, First: Mahnaz, Last: Fatma
ID: 102, Age: 50, First: Zaid, Last: Khan
ID: 103, Age: 45, First: Sumit, Last: Mittal
新しい年齢を示すリザルトセットをリストに...
ID: 100, Age: 38, First: Zara, Last: Ali
ID: 101, Age: 45, First: Mahnaz, Last: Fatma
ID: 102, Age: 55, First: Zaid, Last: Khan
ID: 103, Age: 50, First: Sumit, Last: Mittal
新しいレコードを挿入しています...
新しいセットを示すリザルトセットをリストに...
ID: 100, Age: 38, First: Zara, Last: Ali
ID: 101, Age: 45, First: Mahnaz, Last: Fatma
ID: 102, Age: 55, First: Zaid, Last: Khan
ID: 103, Age: 50, First: Sumit, Last: Mittal
ID: 104, Age: 40, First: John, Last: Paul
削除前のレコードをリストに...
ID: 101, Age: 45, First: Mahnaz, Last: Fatma
一つのレコードを削除した後のリザルトセットをリストに...
ID: 100, Age: 38, First: Zara, Last: Ali
ID: 102, Age: 55, First: Zaid, Last: Khan
ID: 103, Age: 50, First: Sumit, Last: Mittal
ID: 104, Age: 40, First: John, Last: Paul
さようなら!
C:\>