下面提到了带有和没有交易的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
。请澄清我的疑问。
答案 0 :(得分:2)
在第二个示例中,正在使用事务,因为多个插入正在作为事务的一部分执行。如果第二个插入失败,则事务能够回滚第一个插入。它使两个操作都成为一个原子单元。
答案 1 :(得分:1)
JDBC Connection处于自动提交模式,默认为自动提交模式, 然后每个SQL语句在完成后提交给数据库。 出于以下原因,我们希望关闭自动提交并管理您自己的交易:
事务使我们能够控制是否对数据库应用了任何更改。它将单个SQL语句或一组SQL语句视为一个逻辑单元。如果任何语句失败,整个交易将失败。
要启用手动事务而不是JDBC驱动程序的自动提交模式,请使用Connection对象的setAutoCommit()方法。完成更改并想要提交更改后,请调用commit()方法。否则,要使用名为conn的Connection回滚对数据库的更新,请使用
conn.rollback( );
答案 2 :(得分:0)
交易不只是关于提交/回滚..它只是ACID Click中的一个属性..