概述
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);
}
}
最后
以上就是从容自行车为你收集整理的JDBC事务JDBC事务的全部内容,希望文章能够帮你解决JDBC事务JDBC事务所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复