Bootstrap

SpringBoot+JPA项目中使用@Async时,事务失效,只有查询,无法保存数据

    在最近的SpringBoot项目中使用了Spring Data JPA,遇到了一个奇怪的问题,方法使用@Async标注以后,可以异步运行,但是运行时使用@Transactional标注的方法,不能保存数据,打印SQL语句,发现只有SELECT语句,UPDATE/INSERT语句不打印。如果去掉@Async就没有这个问题。

    按照网上说的方法,移动@Async和@Transactional的标注位置,无法解决问题。最后在stackoverflow上发现有个jpa无法保存数据库的问题,现象不一样。但有一个回答说,可能是使用的TransactionManager不对,应该使用JpaTransactionManager,而不是DataSourceTransactionManager。

    使用调试模式确认了一下,果然使用的是DataSourceTransactionManager,将其切换成JpaTransactionManager,问题解决!

    网上资料都说POM中使用spring-boot-starter-data-jpa,SpringBoot会自动配置并使用JpaTransactionManager。不知为什么,我的项目中给自动配置成DataSourceTransactionManager。

@Configuration
@Import(JpaRepository.class)
public class JpaConfig {
    @Bean
    public PlatformTransactionManager transactionManager() {
        return new JpaTransactionManager();
    }
}
备注:
网上有的说法可以在方法上同时@Async和@Transactional这个是错误的。这两个注解都是使用AOP实现的,只能有一个起作用。@Async优先级高会生效。
;