JDBC事务
严格来讲,事务不是JDBC的技术而是数据库的技术。
事务的概念
把连续执行的一系列SQL语句视为一个整体。
PS:这里的SQL语句,主要是DML语句(增删改),DQL用的不多
如何判断是否是一个整体?
整体表示这一系列SQL语句要么都执行成功,要么都不执行。
public void preparedStatementBusiness() {
String sql1 = "UPDATE student SET age=age+10 WEHRE id=3";
String sql2 = "UPDATE student SET age=age+20 WEHRE id=3";
String sql3 = "UPDATE student SET age=age+30 WEHRE id=3";
Connection conn = JdbcUtil.getConnection();
PreparedStatement ps = null;
try {
ps=conn.prepareStatement(sql1);
ps.executeUpdate();
ps=conn.prepareStatement(sql2);
ps.execute();
ps=conn.prepareStatement(sql3);
ps.executeUpdate();
} catch (SQLException e) {
e.printStackTrace();
} finally {
JdbcUtil.close(conn, ps);
}
}
例如上面所示代码中执行的这三条SQL语句就不是一个整体,比如将sql2这个字符串修改成错误的SQL语句,sql1语句依旧会修改数据库的数据,而sql2会因为抛出异常不执行。
事务的三个操作
- 开启事务:取消自动提交事务
- 提交事务:使用commit来主动提交事务
- 回滚事务:如果出现异常,使用rollback将数据回滚到开始事务时
代码演示:
public void preparedStatementBusiness() {
String sql1 = "UPDATE student SET age=age+10 WEHRE id=3";
String sql2 = "UPDATE student SET age=age+20 WEHRE id=3";
String sql3 = "UPDATE student SET age=age+30 WEHRE id=3";
Connection conn = null;
PreparedStatement ps = null;
try {
conn = JdbcUtil.getConnection();
conn.setAutoCommit(false);// 开启事务——取消自动提交
ps = conn.prepareStatement(sql1);
ps.executeUpdate();
ps = conn.prepareStatement(sql2);
ps.execute();
ps = conn.prepareStatement(sql3);
ps.executeUpdate();
conn.commit();// 提交事务
} catch (SQLException e) {
try {
conn.rollback();// 事务回滚
} catch (SQLException e1) {
e1.printStackTrace();
}
e.printStackTrace();
} finally {
JdbcUtil.close(conn, ps);
}
}