springboot 多数据源事务回滚失效

在没有配置多数据源之前,我在service层的方法上加@Transactional是可以正常回滚的。而在我配置了多数据源后,原来的事务都失效了,我还不知道是因为多数据源导致失效的,因此我在网上搜了很久,什么方法都执行了一遍,但是都没有效果。
最后我发现我是在配置了多数据源后才出现这种现象的,我就从多数据源的配置文件下手
加上以下这段,针对动态数据源的事物控制,可以成功回滚。

@Bean
public DataSourceTransactionManager transactionManager(DynamicDataSource dynamicDataSource) {
return new DataSourceTransactionManager(dynamicDataSource);
}


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 {
.........

}

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值