我是靠谱客的博主 从容自行车,最近开发中收集的这篇文章主要介绍JDBC事务JDBC事务,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

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会因为抛出异常不执行。

事务的三个操作

  1. 开启事务:取消自动提交事务
  2. 提交事务:使用commit来主动提交事务
  3. 回滚事务:如果出现异常,使用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事务所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(62)

评论列表共有 0 条评论

立即
投稿
返回
顶部