动态数据源事务回滚失败解决

文章讲述了在SpringBoot应用中遇到的多数据源事务回滚失效的难题,关键在于缺少对应数据源的事务管理器配置。通过添加DataSourceTransactionManager并指定transactionManager,确保了事务的正确回滚。
摘要由CSDN通过智能技术生成

读了n多篇文章,如

spring事务(注解 @Transactional )失效的12种场景

Spring——事务注解@Transactional【建议收藏】

记一次事务失效的问题排查记录

Spring多数据源开启事务

讲的都很好,可惜不对症

终于寻得一篇良药

-》springboot 多数据源事务回滚失效,很赞药到病除

原来是配置中没有加对应数据源的事务管理器

以下借鉴大佬的代码

public class DynamicDbConfig {

private static String MYBATIS_CONFIG = "/mybatis-config.xml";
/**     * mybatis mapper resource 路径     */
private static String MAPPER_PATH = "/mapping/**/*.xml";

private final DataSource dynamicDS;

@Autowired
public DynamicDbConfig(DataSource dynamicSource) {
    this.dynamicDS = dynamicSource;
}

@Bean
public SqlSessionFactory dynamicSqlSessionFactory() throws Exception {
    SqlSessionFactoryBean factoryBean = new SqlSessionFactoryBean();
    factoryBean.setConfigLocation(new ClassPathResource(MYBATIS_CONFIG));

    PathMatchingResourcePatternResolver pathMatchingResourcePatternResolver = new PathMatchingResourcePatternResolver();
    String packageSearchPath = ResourcePatternResolver.CLASSPATH_ALL_URL_PREFIX + MAPPER_PATH;

    factoryBean.setMapperLocations(pathMatchingResourcePatternResolver.getResources(packageSearchPath));
    factoryBean.setDataSource(dynamicDS);
    return factoryBean.getObject();

}

****/**
 * 一定要加上这个,不然事务回滚失效
 * @param dynamicDataSource
 * @return
 */
@Bean
public DataSourceTransactionManager transactionManager(DynamicDataSource dynamicDataSource) {
    return new DataSourceTransactionManager(dynamicDataSource);
}

在开启事务的方法上指定transactionManager (按你命名的写)

@Override
@Transactional(value = "transactionManager", rollbackFor = Exception.class)
public int addFrom(FromModel fromModel) throws BusinessException, ParseException {
.........

侵删~

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值