为什么我们在JDBC中使用事务?

时间:2013-10-21 09:00:03

标签: java sql jdbc transactions

下面提到了带有和没有交易的MY jdbc程序代码。

在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);
      }

使用JDBC中的TRANSACTION

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

两个交易都返回相同的结果,然后我们在TRANSACTIONS中使用JDBC。请澄清我的疑问。

3 个答案:

答案 0 :(得分:2)

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

答案 1 :(得分:1)

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

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

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

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

 conn.rollback( );

参考transaction

答案 2 :(得分:0)

交易不只是关于提交/回滚..它只是ACID Click中的一个属性..