In this post, we want to talk about JDBC Transactions and how we can manage the operations in a database.
The most popular DBMS like MySQL and Oracle have by default the option autocommit enabled, it means immediately after any DML Operation saves the changes and makes them visible to all users. To use transactions must set the databse parameter autocommit to false.
The management of the database using transaction allows us to maintain consistency in the data, according to his ‘ACID’ property.
Transaction Properties
What we want with Transactions? To Maintain this four properties:
- Atomicity, it’s simple either all operations in database occur, or nothing occurs.
- Consistency, ensures that the database is in a valid state before and after the transaction.
- Isolation, any transaction is independent of another, and your result doesn’t depends of any other.
- Durability, the result of commit a transaction must persist in a non-volatile memory even if occurs a crash or power loss.
Tools
For this example we use:
- JDK 1.7.0_67 (rt.jar includes java.sql package)
- Mysql-connector-java 5.1.34
- Eclipse Luna
- MySQL Community Server 5.6.22
1. Example:
DBConnection.java:
| 01 | packagecom.javacodegeeks.jdbc.transactions; | 
 
| 03 | importjava.sql.Connection; | 
 
| 04 | importjava.sql.DriverManager; | 
 
| 05 | importjava.sql.SQLException; | 
 
| 08 |  * @author Andres.Cespedes | 
 
| 11 | publicclassDBConnection { | 
 
| 14 |     privatestaticString DB_USER = "admin"; | 
 
| 15 |     privatestaticString DB_PASSWORD = "admin"; | 
 
| 17 |     publicstaticConnection getConnection() throwsSQLException { | 
 
| 18 |         Connection connection = DriverManager.getConnection(DB_URL, DB_USER, DB_PASSWORD); | 
 
 
 
We use DBConnection only to get the connection, any other operation is handled in the main class.
DBTransaction.java:
| 01 | packagecom.javacodegeeks.jdbc.transactions; | 
 
| 03 | importjava.sql.Connection; | 
 
| 04 | importjava.sql.PreparedStatement; | 
 
| 05 | importjava.sql.SQLException; | 
 
| 08 |  * @author Andres.Cespedes | 
 
| 11 | publicclassDBTransaction { | 
 
| 13 |     privatestaticString INSERT = "INSERT INTO test.department (idDepartment, name) VALUES (?, ?)"; | 
 
| 18 |     publicstaticvoidmain(String[] args) { | 
 
| 19 |         Connection connection = null; | 
 
| 20 |         PreparedStatement pstmt = null; | 
 
| 21 |         PreparedStatement pstmt2 = null; | 
 
| 23 |             connection = DBConnection.getConnection(); | 
 
| 24 |         } catch(SQLException e) { | 
 
| 25 |             System.err.println("There was an error getting the connection"); | 
 
| 28 |             connection.setAutoCommit(false); | 
 
| 29 |             System.err.println("The autocommit was disabled!"); | 
 
| 30 |         } catch(SQLException e) { | 
 
| 31 |             System.err.println("There was an error disabling autocommit"); | 
 
| 35 |             pstmt = connection.prepareStatement(INSERT); | 
 
| 36 |             pstmt2 = connection.prepareStatement(INSERT); | 
 
| 39 |             pstmt.setString(2, "Madrid"); | 
 
| 43 |             pstmt2.setString(2, "Galicia"); | 
 
| 47 |             System.err.println("The transaction was successfully executed"); | 
 
| 48 |         } catch(SQLException e) { | 
 
| 51 |                 connection.rollback(); | 
 
| 52 |                 System.err.println(e.getMessage()); | 
 
| 53 |                 System.err.println("The transaction was rollback"); | 
 
| 54 |             } catch(SQLException e1) { | 
 
| 55 |                 System.err.println("There was an error making a rollback"); | 
 
 
 
The connection.commit() applies all the changes before him. The key is to disable the autocommit and to group the sentences to to manage them in a transaction with a final commit.
We try to execute the transaction and this was the result.
| 1 | The connection is successfully obtained | 
 
| 2 | The autocommit was disabled! | 
 
| 3 | The transaction was successfully executed | 
 
 
 
Here we should note that if one of the operations does not run correctly, all entries aren’t made and the database remains unchanged.
DBSavePoint.java:
| 01 | packagecom.javacodegeeks.jdbc.transactions; | 
 
| 03 | importjava.sql.Connection; | 
 
| 04 | importjava.sql.PreparedStatement; | 
 
| 05 | importjava.sql.SQLException; | 
 
| 06 | importjava.sql.Savepoint; | 
 
| 09 |  * @author Andres.Cespedes | 
 
| 12 | publicclassDBSavePoint { | 
 
| 14 |     privatestaticString INSERT = "INSERT INTO test.department (idDepartment, name) VALUES (?, ?)"; | 
 
| 16 |     publicstaticvoidinsertRow(Connection conn, intidRow, String contentRow) | 
 
| 18 |         PreparedStatement pstmt = null; | 
 
| 19 |         pstmt = conn.prepareStatement(INSERT); | 
 
| 20 |         pstmt.setInt(1, idRow); | 
 
| 21 |         pstmt.setString(2, contentRow); | 
 
| 29 |     publicstaticvoidmain(String[] args) { | 
 
| 30 |         Connection connection = null; | 
 
| 31 |         Savepoint savepoint = null; | 
 
| 33 |             connection = DBConnection.getConnection(); | 
 
| 34 |         } catch(SQLException e) { | 
 
| 35 |             System.err.println("There was an error getting the connection"); | 
 
| 38 |             connection.setAutoCommit(false); | 
 
| 39 |             System.err.println("The autocommit was disabled!"); | 
 
| 40 |         } catch(SQLException e) { | 
 
| 41 |             System.err.println("There was an error disabling autocommit"); | 
 
| 45 |             insertRow(connection, 1, "Madrid"); | 
 
| 46 |             insertRow(connection, 2, "Eibar"); | 
 
| 47 |             savepoint = connection.setSavepoint("SavePoint1"); | 
 
| 48 |             insertRow(connection, 3, "Galicia"); | 
 
| 51 |             System.err.println("The transaction was successfully executed"); | 
 
| 52 |         } catch(SQLException e) { | 
 
| 55 |                 connection.rollback(savepoint); | 
 
| 56 |                 System.err.println(e.getMessage()); | 
 
| 58 |                         .println("The transaction was rollback to the last savepoint"); | 
 
| 59 |             } catch(SQLException e1) { | 
 
| 60 |                 System.err.println("There was an error making a rollback"); | 
 
 
 
The method setSavepoint of class Connection allows to create a checkpoint internally in the transaction, and if a error occurs we can back to the savepoint with all of changes made before.
2. Summary
Here we tried to understand how to manage the JDBC Operations through transactions and how to make check points by means ofSavePoint class.
 
http://examples.javacodegeeks.com/core-java/sql/jdbc-transaction-management-example/
JDBC Transaction Management Example---reference
原文:http://www.cnblogs.com/davidwang456/p/4215864.html