JDBC-バッチ処理

バッチ処理を使用すると、関連するSQLステートメントをバッチにグループ化し、データベースへの1回の呼び出しでそれらを送信できます。

複数のSQLステートメントを一度にデータベースに送信すると、通信オーバーヘッドの量が減り、パフォーマンスが向上します。

  • この機能をサポートするためにJDBCドライバーは必要ありません。あなたは使用する必要があります()DatabaseMetaData.supportsBatchUpdatesをターゲット・データベースがバッチ更新処理をサポートしているかどうかを判断する方法。JDBCドライバーがこの機能をサポートしている場合、メソッドはtrueを返します。

  • ザ・ addBatch()Statement、PreparedStatement、およびCallableStatementのメソッドは個々のステートメントをバッチに追加するために使用されます。ザ・executeBatch() グループ化されたすべてのステートメントの実行を開始するために使用されます。

  • ザ・ executeBatch() 整数の配列を返します。配列の各要素は、それぞれの更新ステートメントの更新カウントを表します。

  • 処理のためにステートメントをバッチに追加できるのと同じように、 clearBatch()方法。このメソッドは、addBatch()メソッドで追加したすべてのステートメントを削除します。ただし、削除するステートメントを選択的に選択することはできません。

ステートメントオブジェクトを使用したバッチ処理

これは、ステートメントオブジェクトでバッチ処理を使用するための一般的な一連の手順です。

  • いずれかのcreateStatement()メソッドを使用してStatementオブジェクトを作成します。

  • setAutoCommit()を使用して自動コミットをfalseに設定します。

  • 作成されたステートメントオブジェクトでaddBatch()メソッドを使用して、必要な数のSQLステートメントをバッチに追加します。

  • 作成されたステートメントオブジェクトに対してexecuteBatch()メソッドを使用して、すべてのSQLステートメントを実行します。

  • 最後に、commit ()メソッドを使用してすべての変更をコミットします。

次のコードスニペットは、Statementオブジェクトを使用したバッチ更新の例を示しています-

// Create statement object
Statement stmt = conn.createStatement();

// Set auto-commit to false
conn.setAutoCommit(false);

// Create SQL statement
String SQL = "INSERT INTO Employees (id, first, last, age) " +
             "VALUES(200,'Zia', 'Ali', 30)";
// Add above SQL statement in the batch.
stmt.addBatch(SQL);

// Create one more SQL statement
String SQL = "INSERT INTO Employees (id, first, last, age) " +
             "VALUES(201,'Raj', 'Kumar', 35)";
// Add above SQL statement in the batch.
stmt.addBatch(SQL);

// Create one more SQL statement
String SQL = "UPDATE Employees SET age = 35 " +
             "WHERE id = 100";
// Add above SQL statement in the batch.
stmt.addBatch(SQL);

// Create an int[] to hold returned values
int[] count = stmt.executeBatch();

//Explicitly commit statements to apply changes
conn.commit();

理解を深めるために、バッチ処理-サンプルコードを調べてみましょう。

PrepareStatementオブジェクトを使用したバッチ処理

これは、PrepareStatementオブジェクトでバッチ処理を使用するための一般的な一連の手順です。

  1. プレースホルダーを使用してSQLステートメントを作成します。

  2. いずれかのprepareStatement() メソッドを使用してPrepareStatementオブジェクトを作成します。

  3. setAutoCommit()を使用して自動コミットをfalseに設定します。

  4. 作成されたステートメントオブジェクトでaddBatch()メソッドを使用して、必要な数のSQLステートメントをバッチに追加します。

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

  6. 最後に、commit ()メソッドを使用してすべての変更をコミットします。

次のコードスニペットは、PrepareStatementオブジェクトを使用したバッチ更新の例を示しています-

// Create SQL statement
String SQL = "INSERT INTO Employees (id, first, last, age) " +
             "VALUES(?, ?, ?, ?)";

// Create PrepareStatement object
PreparedStatemen pstmt = conn.prepareStatement(SQL);

//Set auto-commit to false
conn.setAutoCommit(false);

// Set the variables
pstmt.setInt( 1, 400 );
pstmt.setString( 2, "Pappu" );
pstmt.setString( 3, "Singh" );
pstmt.setInt( 4, 33 );
// Add it to the batch
pstmt.addBatch();

// Set the variables
pstmt.setInt( 1, 401 );
pstmt.setString( 2, "Pawan" );
pstmt.setString( 3, "Singh" );
pstmt.setInt( 4, 31 );
// Add it to the batch
pstmt.addBatch();

//add more batches
.
.
.
.
//Create an int[] to hold returned values
int[] count = stmt.executeBatch();

//Explicitly commit statements to apply changes
conn.commit();

理解を深めるために、バッチ処理-サンプルコードを調べてみましょう。