JDBC-일괄 처리

일괄 처리를 사용하면 관련 SQL 문을 일괄 처리로 그룹화하고 한 번의 호출로 데이터베이스에 제출할 수 있습니다.

한 번에 여러 SQL 문을 데이터베이스에 보낼 때 통신 오버 헤드 양이 줄어들어 성능이 향상됩니다.

  • 이 기능을 지원하는 데 JDBC 드라이버는 필요하지 않습니다. 당신은 사용해야 DatabaseMetaData.supportsBatchUpdates () 대상 데이터베이스가 배치 갱신 처리를 지원하는지 확인하는 방법을. JDBC 드라이버가이 기능을 지원하는 경우 메서드는 true를 반환합니다.

  • 그만큼 addBatch()Statement, PreparedStatementCallableStatement의 메소드는 개별 명령문을 배치에 추가하는 데 사용됩니다. 그만큼executeBatch() 함께 그룹화 된 모든 명령문의 실행을 시작하는 데 사용됩니다.

  • 그만큼 executeBatch() 정수 배열을 반환하고 배열의 각 요소는 각 업데이트 문에 대한 업데이트 수를 나타냅니다.

  • 처리를 위해 일괄 처리에 문을 추가 할 수있는 것처럼 clearBatch()방법. 이 메서드는 addBatch () 메서드로 추가 한 모든 문을 제거합니다. 그러나 제거 할 문을 선택적으로 선택할 수는 없습니다.

Statement 객체로 일괄 처리

다음은 Statement Object와 함께 일괄 처리를 사용하는 일반적인 단계 순서입니다.

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

더 나은 이해를 위해 Batching-Example Code를 살펴 보겠습니다 .

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

더 나은 이해를 위해 Batching-Example Code를 살펴 보겠습니다 .