0

MY jdbc program code with and with out transaction is mentioned below.

WITHOUT TRANSACTION IN JDBC

stmt = conn.createStatement();

      System.out.println("creating statement....");
      String sql;
      sql = " INSERT INTO testing VALUES (3,  'Rita', 'Tez','vizag')";
      stmt.executeUpdate(sql);
      System.out.println("deleted.....");
      sql = "SELECT s_no,s_name,s_group,s_area  from testing group by s_no,s_name,s_group, s_area";
      ResultSet rs = stmt.executeQuery(sql);
      while(rs.next()){


         String s_name = rs.getString("s_name");


         System.out.println("employees names:" +s_name);
      }

WITH TRANSACTION IN JDBC

conn.setAutoCommit(false);



      System.out.println("Creating statement...");
      stmt = conn.createStatement(
                           ResultSet.TYPE_SCROLL_INSENSITIVE,
                           ResultSet.CONCUR_UPDATABLE);


      System.out.println("Inserting one row....");
      String SQL = "INSERT INTO testing " +
                    "VALUES (3,  'Rita', 'Tez','vizag')";
      stmt.executeUpdate(SQL);  


      SQL = "INSERT INTO testing " +
                    "VALUES (4,  'Sita', 'Singh','hyd')";
      stmt.executeUpdate(SQL);


      System.out.println("Commiting data here....");
      conn.commit();


      String sql = "SELECT  s_no,s_name,s_group,s_area FROM testing group by s_no,s_name,s_group,s_area ";
      ResultSet rs = stmt.executeQuery(sql);
      System.out.println("List result set for reference....");
      printRs(rs);


      rs.close();
      stmt.close();
      conn.close();
   }catch(SQLException se){

      se.printStackTrace();

      System.out.println("Rolling back data here....");
      try{
         if(conn!=null)
            conn.rollback();
      }catch(SQLException se2){
         se2.printStackTrace();
      }

   }catch(Exception e){

      e.printStackTrace();
   }finally{

      try{
         if(stmt!=null)
            stmt.close();
      }catch(SQLException se2){
      }
      try{
         if(conn!=null)
            conn.close();
      }catch(SQLException se){
         se.printStackTrace();
      }
   }

}

   public static void printRs(ResultSet rs) throws SQLException{

      rs.beforeFirst();
      while(rs.next()){

         int s_no = rs.getInt("s_no");
         String s_name = rs.getString("s_name");
         String s_group = rs.getString("s_group");
         String s_area = rs.getString("s_area");


         System.out.print("s_no: " + s_no);
         System.out.print(", s_name: " + s_name);
         System.out.print(", s_group: " + s_group);
         System.out.println(", s_area: " + s_area);
     }
     System.out.println();
   }
}

Both transactions are returning same results,then y we use TRANSACTIONS in JDBC.Please clarify my doubt.

4

3 回答 3

2

在第二个示例中,使用了事务,因为作为事务的一部分正在执行多个插入。如果第二次插入失败,事务能够回滚第一次插入。它使这两个操作成为一个原子单元。

于 2013-10-21T09:03:19.610 回答
1

JDBC Connection 处于自动提交模式,默认情况下是自动提交模式,然后每条 SQL 语句在完成后都会提交到数据库。出于以下原因,我们希望关闭自动提交并管理您自己的交易:

  • 提高性能
  • 维护业务流程的完整性

事务使我们能够控制是否对数据库应用了任何更改。它将单个 SQL 语句或一组 SQL 语句视为一个逻辑单元。如果任何语句失败,则整个事务将失败。

要启用手动事务而不是 JDBC 驱动程序的自动提交模式,请使用 Connection 对象的 setAutoCommit() 方法。一旦我们完成更改并想要提交更改,然后调用 commit() 方法。否则,要回滚使用名为 conn 的连接对数据库进行的更新,请使用

 conn.rollback( );

参考交易

于 2013-10-21T09:14:20.610 回答
0

事务不仅仅是提交/回滚。它只是 ACID Click中的一个属性。

于 2013-11-19T19:20:16.440 回答