Java JDBC程序中对于数据库事务的处理详解
Posted 路宇
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java JDBC程序中对于数据库事务的处理详解相关的知识,希望对你有一定的参考价值。
一、JDBC中对于事务的介绍
二、使用事务模拟经典的转账业务
下面代码中演示JDBC中没有使用事务,和使用事务的两种情况
//演示jdbc 中如何使用事务
public class Transaction_
//没有使用事务
@Test
public void noTransaction()
//1.得到连接
Connection connection = null;
//2.组织一个sql
//更新记录
String sql = "UPDATE ACCOUNT SET balance=balance-100 WHERE id=1";
String sql2 = "UPDATE ACCOUNT SET balance=balance+100 WHERE id=2";
PreparedStatement preparedStatement = null;
//创建PrepareStatement对象
try
connection = JDBCUtils.getConnection(); //在默认情况下,connection对象是默认自动提交的
preparedStatement = connection.prepareStatement(sql);
preparedStatement.executeUpdate();
int i = 1 / 0;
preparedStatement = connection.prepareStatement(sql2);
preparedStatement.executeUpdate();
catch (SQLException e)
e.printStackTrace();
finally
//关闭资源
JDBCUtils.close(null, preparedStatement, connection);
//使用事务
@Test
public void useTransaction()
//1.得到连接
Connection connection = null;
//2.组织一个sql
//更新记录
String sql = "UPDATE ACCOUNT SET balance=balance-100 WHERE id=1";
String sql2 = "UPDATE ACCOUNT SET balance=balance+100 WHERE id=2";
PreparedStatement preparedStatement = null;
//创建PrepareStatement对象
try
connection = JDBCUtils.getConnection(); //在默认情况下,connection对象是默认自动提交的
//将connection 设置为不自动提交
connection.setAutoCommit(false);//开启事务
preparedStatement = connection.prepareStatement(sql);
preparedStatement.executeUpdate();
// int i = 1 / 0;
preparedStatement = connection.prepareStatement(sql2);
preparedStatement.executeUpdate();
//这里提交事务
connection.commit();
catch (SQLException e)
//这里我们可以进行回滚,即撤销执行的sql
//默认回滚到事务开始的状态
try
connection.rollback();
catch (SQLException throwables)
throwables.printStackTrace();
e.printStackTrace();
finally
//关闭资源
JDBCUtils.close(null, preparedStatement, connection);
说明:这里使用到了JDBCUtils这个工具类 在这篇文章
Java 中封装JDBC连接到JDBCUtils工具类的详解
以上是关于Java JDBC程序中对于数据库事务的处理详解的主要内容,如果未能解决你的问题,请参考以下文章