JDBC-트랜잭션

JDBC 연결이 기본적으로 자동 커밋 모드 인 경우 모든 SQL 문은 완료시 데이터베이스에 커밋됩니다.

간단한 애플리케이션에서는 괜찮을 수 있지만 자동 커밋을 끄고 자신의 트랜잭션을 관리해야하는 세 가지 이유가 있습니다.

  • 성능 향상.

  • 비즈니스 프로세스의 무결성을 유지합니다.

  • 분산 트랜잭션을 사용합니다.

트랜잭션을 사용하면 변경 사항이 데이터베이스에 적용되는지 여부와시기를 제어 할 수 있습니다. 단일 SQL 문 또는 SQL 문 그룹을 하나의 논리 단위로 취급하고 문이 실패하면 전체 트랜잭션이 실패합니다.

JDBC 드라이버가 기본적으로 사용하는 자동 커밋 모드 대신 수동 트랜잭션 지원을 활성화하려면 Connection 개체의setAutoCommit()방법. 부울 false를 setAutoCommit ()에 전달하면 자동 커밋이 해제됩니다. 부울 true를 전달하여 다시 켤 수 있습니다.

예를 들어, 이름이 conn 인 Connection 객체가있는 경우 다음을 코딩하여 자동 커밋을 해제합니다.

conn.setAutoCommit(false);

커밋 및 롤백

변경 사항을 완료하고 변경 사항을 커밋하려면 다음을 호출하십시오. commit() 다음과 같이 연결 개체에 대한 방법-

conn.commit( );

그렇지 않으면 conn이라는 연결을 사용하여 만든 데이터베이스로 업데이트를 롤백하려면 다음 코드를 사용하십시오.

conn.rollback( );

다음 예제는 커밋 및 롤백 객체의 사용을 보여줍니다-

try{
   //Assume a valid connection object conn
   conn.setAutoCommit(false);
   Statement stmt = conn.createStatement();
   
   String SQL = "INSERT INTO Employees  " +
                "VALUES (106, 20, 'Rita', 'Tez')";
   stmt.executeUpdate(SQL);  
   //Submit a malformed SQL statement that breaks
   String SQL = "INSERTED IN Employees  " +
                "VALUES (107, 22, 'Sita', 'Singh')";
   stmt.executeUpdate(SQL);
   // If there is no error.
   conn.commit();
}catch(SQLException se){
   // If there is any error.
   conn.rollback();
}

이 경우 위의 INSERT 문 중 어느 것도 성공하지 않고 모든 것이 롤백됩니다.

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

세이브 포인트 사용

새로운 JDBC 3.0 Savepoint 인터페이스는 추가적인 트랜잭션 제어를 제공합니다. 대부분의 최신 DBMS는 Oracle의 PL / SQL과 같은 환경 내에서 저장 점을 지원합니다.

저장 점을 설정할 때 트랜잭션 내에서 논리적 롤백 지점을 정의합니다. 저장 점을 지나서 오류가 발생하면 롤백 방법을 사용하여 모든 변경 사항을 실행 취소하거나 저장 점 이후의 변경 사항 만 취소 할 수 있습니다.

Connection 객체에는 저장 점을 관리하는 데 도움이되는 두 가지 새로운 방법이 있습니다.

  • setSavepoint(String savepointName):새 저장 점을 정의합니다. 또한 Savepoint 개체를 반환합니다.

  • releaseSavepoint(Savepoint savepointName):저장 점을 삭제합니다. 매개 변수로 Savepoint 객체가 필요합니다. 이 객체는 일반적으로 setSavepoint () 메서드에 의해 생성 된 저장 점입니다.

하나 있습니다 rollback (String savepointName) 지정된 저장 점으로 작업을 롤백하는 메소드.

다음 예제는 Savepoint 객체의 사용을 보여줍니다-

try{
   //Assume a valid connection object conn
   conn.setAutoCommit(false);
   Statement stmt = conn.createStatement();
   
   //set a Savepoint
   Savepoint savepoint1 = conn.setSavepoint("Savepoint1");
   String SQL = "INSERT INTO Employees " +
                "VALUES (106, 20, 'Rita', 'Tez')";
   stmt.executeUpdate(SQL);  
   //Submit a malformed SQL statement that breaks
   String SQL = "INSERTED IN Employees " +
                "VALUES (107, 22, 'Sita', 'Tez')";
   stmt.executeUpdate(SQL);
   // If there is no error, commit the changes.
   conn.commit();

}catch(SQLException se){
   // If there is any error.
   conn.rollback(savepoint1);
}

이 경우 위의 INSERT 문 중 어느 것도 성공하지 않고 모든 것이 롤백됩니다.

더 나은 이해를 위해 세이브 포인트-예제 코드를 살펴 보겠습니다 .