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);
	}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值