事务:针对关系型数据库的一种机制
就是在执行业务操作过程中,同事执行多个 sql或者多张表的sql(添加,删除,修改)),这些sql语句要么同时执行成功,要么同时执行失败;
//声明Connection类型变量
Connection connection = null ;
PreparedStatement ps = null ;
PreparedStatement ps2 = null ;
try {
//没有通过jdbc管理事务-----当同时执行多条sql,中间如果存在异常,第一条件语句成功了,第二条数据失败;
// 转账业务失败----->应该在jdbc操作转账的业务中加入事务操作!
//使用Jdbc控制事务--->通过获取连接对象之后,加入事务的方法
//通过工具类获取连接对象
connection = DruidJdbcUtils.getConnection();
//开启事务---->利用Connection的功能void setAutoCommit(boolean autoCommit):默认自动提交
//参数为false:禁用自动提交,需要手动提交事务
connection.setAutoCommit(false) ;
//准备sql---参数化sql
String sql = "update account set balance = balance - ? where id = ?" ;
//获取预编译对象
ps = connection.prepareStatement(sql);
//参数赋值
ps.setInt(1,500) ;
ps.setInt(2,1) ;
String sql2 = "update account set balance = balance + ? where id = ?" ;
//获取预编译对象
ps2 = connection.prepareStatement(sql2);
ps2.setInt(1,500) ;
ps2.setInt(2,2);
//分别执行更新操作
int count = ps.executeUpdate();
int i = 10/0 ;
int count2 = ps2.executeUpdate();
System.out.println(count+"---"+count2);
//提交事务: 如果没有问题,提交事务---数据在能永久更新
//Connection对象的方法:void commit()
} catch (Exception e) {
System.out.println("执行catch语句");
//出现异常,程序执行catch语句
//事务回滚
//连接对象的方法void rollback():回滚到默认在更新之前的操作
try {
connection.rollback() ;
} catch (SQLException ex) {
ex.printStackTrace();
}
e.printStackTrace();
/*System.out.println("异常抛出了");*/
}finally {
//任何情况下finally中的代码一定会执行的,除非 只执行这个语句之前,jvm退出了 System.exit(0) ;
try {
connection.commit();
} catch (SQLException e) {
e.printStackTrace();
}
//释放资源
DruidJdbcUtils.close(ps,connection);
DruidJdbcUtils.close(ps2,connection);
}
}
}