Java 中对数据库操作时的 回滚

本文介绍了使用JDBC进行数据库事务管理,包括添加、修改、删除操作中的事务提交与回滚,确保数据完整性和一致性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Connection conn=null; 
conn.rollback()就可以回滚
//用jdbc连接数据库
//举例子,比如你在写一个级联删除的方法的时候,为了保证数据完整性,删除的时候一定要确定该删的都删了才行,否则就要回滚,下面是删除方法的例子:

public boolean delete(int sID) {//成功删除会返回true;
 dbc = new DataBaseConnection();//根据你自己的方式创建数据库的连接
 Connection con = dbc.getConnection();//得到Connection
 try {
  con.setAutoCommit(false);// 更改JDBC事务的默认提交方式,默认是true,是自动提交;
  dbc.executeUpdate("delete from xiao where ID=" + sID);//删除
  dbc.executeUpdate("delete from xiao_content where ID=" + sID);//删除
  dbc.executeUpdate("delete from xiao_affix where bylawid=" + sID);//删除
  con.commit();//提交JDBC事务,如果没问题,这时才真正的删除了;
  con.setAutoCommit(true);// 恢复JDBC事务的默认提交方式,这是个好习惯;
  dbc.close();//关闭连接
  return true;//删除成功
 }
 catch (Exception exc) {
  con.rollBack();//回滚JDBC事务,出现异常,为保证数据完整性,此次操作回滚,不删除;
  exc.printStackTrace();//输出异常信息;
  dbc.close();//关闭连接
  return false;//删除失败
 }
}

//顺便说一下,java中JDBC的事务管理,跟你用的是什么数据库没关系,用什么数据库都是这样;


//做添加操作

Connection con = null;
PreparedStatement ps = null;
ResultSet rs = null;
String tableName = args[0];
Integer id = JdbcUtil.parseInt(args[1]);
String name = args[2];
String command = args[3];
try{
con = JdbcUtil.getConnection();
con.setAutoCommit(false);
String sql = "insert into "+tableName+
" values(?,?)";
ps = con.prepareStatement(sql);
ps.setInt(1,id);
ps.setString(2,name);
ps.executeUpdate();
con.commit();//手动提交

}catch(Exception e){
System.out.println(e.getMessage());
try{
con.rollback();//手动回滚
}catch(Exception ex){
System.out.println(ex.getMessage());
}
}finally{
JdbcUtil.close(rs,ps,con);
}


//做修改操作

try {
conn = DriverManager.getConnection("jdbc:microsoft:sqlserver://localhost:1433;User=JavaDB;Password=javadb;DatabaseName=northwind);
//点禁止自动提交,设置回退
conn.setAutoCommit(false);
stmt = conn.createStatement();
//数据库更新操作1
stmt.executeUpdate(“update firsttable Set Name='testTransaction' Where ID = 1”);

//数据库更新操作2
stmt.executeUpdate(“insert into firsttable ID = 12,Name = 'testTransaction2'”);
//事务提交

conn.commit();
}
catch(Exception ex) {
ex.printStackTrace();
try {
//操作不成功则回退
conn.rollback();
}
catch(Exception e){
  e.printStackTrace();
  }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值