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

JDBCはStatementオブジェクトを使用してバッチを実行します。

これはバッチとStatementオブジェクトを一緒に使用する典型的な手順シーケンスです。-

  1. これらの2つを使用します。createStatement()メソッドは、Statementオブジェクトを作成します。

  2. 自動コミットをfalseに設定するために使用されます。 setAutoCommit()

  3. を使用しますaddBatch()作成された文のオブジェクトにメソッドは、任意の多くのSQL文をバッチに追加します。

  4. を使用しますexecuteBatch()作成したステートメントオブジェクトのメソッドを使用してすべてのSQL文を実行します。

  5. 最後に、commit()すべての変更をコミットする方法

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

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

// 必要なパッケージをインポートします
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;
   Statement stmt = null;
   if(conn!=null)
      // JDBCドライバを登録します
      Class.forName("com.mysql.jdbc.Driver");
      // 接続を開きます
      System.out.println("データベースに接続中...");
      conn = DriverManager.getConnection(DB_URL,USER,PASS);
      // ステートメントの作成
      System.out.println("ステートメントの作成中...");
      stmt = conn.createStatement();
      // 自動コミットをfalseに設定します
      conn.setAutoCommit(false);
      // まず、すべてのレコードを選択して表示します。
      環境をクリーンアップ
  
      // SQL文を生成します
      String SQL = "INSERT INTO Employees (id, first, last, age) " + 
                   "VALUES(200,'Zia', 'Ali', 30)";
      // 上記のSQLステートメントをバッチに追加。
      stmt.addBatch(SQL);
      // もう一つのSQLステートメントを作成
      SQL = "INSERT INTO Employees (id, first, last, age) " +
            "VALUES(201,'Raj', 'Kumar', 35)";
      // 上記のSQLステートメントをバッチに追加。
      stmt.addBatch(SQL);
      // もう一つのSQLステートメントを作成
      SQL = "UPDATE Employees SET age =" 35 " +
            "WHERE id =" 100";
      // 上記のSQLステートメントをバッチに追加。
      stmt.addBatch(SQL);
      // 戻り値を保存するためのint []を作成
      int[] count = stmt.executeBatch();
      //変更を適用するために明示的なコミットステートメント
      conn.commit();
      // printRows( stmt );
      環境をクリーンアップ
      // JDBCエラーの処理
      catch(SQLException se
      catch(SQLException se){
   }
      //catch(Exception e){
      se.printStackTrace();
   }
      //e.printStackTrace();
      finally{
   }
      //リソースを閉じるためのもの
      if(conn!=null)
         stmt.close();
            catch(SQLException se
      }2try{
      
      }
      if(conn!=null)
         conn.close();
            catch(SQLException se){
      }
         se.printStackTrace();
      }
   }
   System.out.println("さようなら!");
}//mainの終了
public static void printRows(Statement stmt) throws SQLException{
   System.out.println("表示可能な行を表示しています...");
   // すべてのレコードを選択して表示します。
   String sql = "SELECT id, first, last, age FROM Employees";
   ResultSet rs = stmt.executeQuery(sql);
   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);
      System.out.print(", First: " + first);
      System.out.println(", Last: " + last);
   }
   System.out.println();
   rs.close();
}//printRows()を終了
}//JDBCExampleを終了

次に、上記の例を以下のようにコンパイルします:

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

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

C:\>java JDBCExample
データベースに接続しています...
ステートメントの作成...
利用可能な行を表示しています...
ID: 95, Age: 2, First: Sima, Last: Chug
ID: 100, Age: 18, First: Zara, Last: Ali
ID: 101, Age: 25, First: Mahnaz, Last: Fatma
ID: 102, Age: 3, First: Zaid, Last: Khan
ID: 103, Age: 3, First: Sumit, Last: Mittal
ID: 110, Age: 2, First: Sima, Last: Chug
利用可能な行を表示しています...
ID: 95, Age: 2, First: Sima, Last: Chug
ID: 100, Age: 35, First: Zara, Last: Ali
ID: 101, Age: 25, First: Mahnaz, Last: Fatma
ID: 102, Age: 3, First: Zaid, Last: Khan
ID: 103, Age: 3, First: Sumit, Last: Mittal
ID: 110, Age: 2, First: Sima, Last: Chug
ID: 200, Age: 3, First: Zia, Last: Ali
ID: 201, Age: 35, First: Raj, Last: Kumar
さようなら!
C:\>