Using a Transaction in JDBC with Exception catching : Transation « Database « Java Tutorial






import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.Statement;

public class Main {
  public static void main(String[] args) throws Exception {
    Connection conn = getHSQLConnection();
    
    conn.setAutoCommit(false);
    Statement st = conn.createStatement();
    try {
      st.executeUpdate("create table survey (id int,name varchar(30));");
      st.executeUpdate("insert into survey (id,name ) values (1,'nameValue')");
      st.executeUpdate("insert into survey (id,name ) values (2,'nameValue')");
       // commits all the transactions
       conn.commit();
    }
    catch (Exception e){
       //cancel (roll back) all the transactions
       conn.rollback();
       // to see what went wrong
       e.printStackTrace();
    }
    
    
    
    st = conn.createStatement();
    ResultSet rs = st.executeQuery("SELECT * FROM survey");

    outputResultSet(rs);

    rs.close();
    st.close();
    conn.close();
  }

  private static void outputResultSet(ResultSet rs) throws Exception {
    ResultSetMetaData rsMetaData = rs.getMetaData();
    int numberOfColumns = rsMetaData.getColumnCount();
    for (int i = 1; i < numberOfColumns + 1; i++) {
      String columnName = rsMetaData.getColumnName(i);
      System.out.print(columnName + "   ");

    }
    System.out.println();
    System.out.println("----------------------");

    while (rs.next()) {
      for (int i = 1; i < numberOfColumns + 1; i++) {
        System.out.print(rs.getString(i) + "   ");
      }
      System.out.println();
    }

  }

  private static Connection getHSQLConnection() throws Exception {
    Class.forName("org.hsqldb.jdbcDriver");
    String url = "jdbc:hsqldb:mem:data/tutorial";
    return DriverManager.getConnection(url, "sa", "");
  }
}
ID   NAME   
----------------------
1   nameValue   
2   nameValue








20.32.Transation
20.32.1.JDBC Transaction Isolation Levels
20.32.2.Transaction Isolation Level supported
20.32.3.Determine if a Database Supports Transactions
20.32.4.Turning On Autocommit Mode
20.32.5.Roll Back a Transaction
20.32.6.Using a Transaction in JDBC with Exception catching
20.32.7.Rollback to savepoint
20.32.8.Using a database transaction with JDBC
20.32.9.Determining If a Database Supports Transactions
20.32.10.Committing and Rolling Back Updates to a Database
20.32.11.Disable auto commit mode in JDBC
20.32.12.If database support transaction
20.32.13.Commit or rollback transaction in JDBC