最近忙得要死(┬_┬),记录一下前几天遇到的一个使用spring管理事务的项目中,事务不生效问题。
最近项目中有一处逻辑较为复杂,涉及到多少张表操作的方法。在开发过程中,偶然发现事务竟然不能正常生效,明明抛出异常了,执行过的数据更新还是没有被回滚。带着沉痛的心情,反复审视这这段代码。因为在之前由测试过项目的事务管理,是生效的,为何现在不生效了,不是说代码不会骗人么???
找了半天原因,问题出在了sping配置文件中的事务管理器上了。查到的相关具体描述如下:
spring中常用的事务管理有DataSourceTransactionManager 和HibernateTransactionManager
平时开发中,大家应该比较少去注意到项目中选用的事务管理器以及这两种事务管理器的区别。两者区别如下:
DataSourceTransactionManager:针对传统的JDBC进行事务管理,在spring中是对JdbcTemplate进行事务管理
HibernateTransactionManager:对Hibernate进行事务管理,当在spring中使用HibernateTemplate时,要使用此管理器。
不巧,我的这个事务出问题的方法就是及使用了JdbcTemplate,又使用了HibernateTemplate,且事务管理器用的DataSourceTransactionManager。
将其更换为HibernateTransactionManager后,问题解决。
当在service的一个方法中同时使用了JdbcTemplate和HibernateTemplate时,就要使用HibernateTransactionManager了,因为当使用DataSourceTransactionManager时,JdbcTemplate和HibernateTemplate获得的connection并不是同一个,也就没办法对service的方法进行事务管理了。
具体原因,参考博文:http://bjyzxxds.iteye.com/blog/427309