Spring默认的事务是自动开启的,我么们没执行一次DAO就是获取了一次连接,这样无法实现多条操作统一提交,比如转账,这时我们一种解决思路就是将connection连接与当前线程绑定,这样我们这么线程在操作时,获取的都是同一个连接。
创建连接工具类
/**
* 连接的工具类,它用于从数据源中获取一个连接,并且实现和线程的绑定
*/
public class ConnectionUtils {
private ThreadLocal<Connection> tl = new ThreadLocal<Connection>();
//提供一个set方法,在xml中让Spring帮我们注入
private DataSource dataSource;
public void setDataSource(DataSource dataSource) {
this.dataSource = dataSource;
}
/**
* 获取当前线程上的连接
*
* @return
*/
public Connection getThreadConnection() {
//1、先从ThreadLocal上获取
Connection conn = tl.get();
try {
//2、判断当前线程上是否有连接
if (conn == null) {
//3、从数据源中获取一个连接,并且存入ThreadLocal中
conn = dataSource.getConnection();
//绑定!!!!!!!!!要不每次都重新获取,不一样的连接对象,无法统一管理!
tl.set(conn);
}
//4 返回当前线程上的连接
return conn;
} catch (SQLException e) {
e.printStackTrace();
throw new RuntimeException(e);
}
}
/**
* 把连接和线程解绑
*/
public void removeConnection(){
tl.remove();
}
}
创建事务的工具类
在事务的工具类中,我们可以获取到线程上的这个唯一的连接,注意开启事务的时候需要将Spring自动的事务管理关闭
/**
* 和事务管理相关的工具类,它包含了:
* 1、开启事务 2、 提交事务 3、 回滚事务 4、 释放连接
*/
public class TransactionManager {
//提供一个set方法,让Spring帮我们注入进来
private ConnectionUtils connectionUtils;
public void setConnectionUtils(ConnectionUtils connectionUtils) {
this</