1、DAO和事务管理的牵绊
1.1、ORM框架和JDBC整合的事务
Spring对混合数据访问技术框架所提供的事务管理器如下:
1.2哪些方法签名不能被Spring AOP事务增强
如图:
2、数据连接泄露
2.1、底层连接资源的访问问题
(1)什么是
数据连接泄露问题:
我们从数据源获取连接,使用完后不主动归还给数据源,则这个连接就会永久被占用,就会造成数据连接泄露问题。
(2)Spring提供的数据访问模板等不会存在连接泄露问题,但是如果代码比较老,需要获取底层的Connection连接,那么Spring提供了2种方式:
- 使用数据源获取工具类;
- 对数据源进行代理。
2.2、通过DataSourceUtils获取数据连接
(1)Spring的JdbcTemplate内部也是通过DataSourceUtils获取数据连接的,DataSourceUtils的方法如下:
(2)通过DataSourceUtils获取数据连接的代码如下:
(3)
上述logon方法上如果没有@Transactional事务注解,及
DataSourceUtils不是在事务上下文中获取的数据连接,则依然会造成连接泄露。解决的方法是显示使用DataSourceUtils释放连接。
2.3、使用TransactionAwareDataSourceProxy
如果不得已要显式获取数据连接,除了使用DataSourceUtils获取事务上下文绑定的连接外,还可以通过TransactionAwareDataSourceProxy对数据源进行代理。
数据源对象被代理后,就具有了事务上下文感知的能力,通过代理数据源的getConnection()方法获取连接和使用DataSourceUtils#getConnection()获取连接的效果是一样的。
代理数据源的配置如下:
2.4、其他数据访问技术的等价类
如图: