避坑spring整合mybatis事务不生效问题

本文探讨了在使用Spring整合MyBatis时遇到的事务不生效问题,并详细介绍了如何确保SqlSessionFactoryBean与SqlSessionTemplate使用同一数据源来正确管理事务。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

作者最近在用spring整合mybatis的时候碰到一个问题就是开启声明式事务之后发现事务不生效,出现异常之后不回滚,在网上查阅很多资料后都没有成功解决。最后仔细检查代码之后发现SqlSessionFactoryBean和事务SqlSessionTemplate用的不是一个数据源导致事务没有生效。

//数据源
    @Bean
    public DataSource dataSource() throws Exception {
        Properties properties = new Properties();
        InputStream resource = SpringConfig.class.getClassLoader().getResourceAsStream("jdbc.properties");
        properties.load(resource);
        DataSource dataSource = DruidDataSourceFactory.createDataSource(properties);
        return dataSource;
    }

代码修改为这样就可以了,用同一个数据源。

  //@Autowired DataSource darrSource自己寻找注入到bean
@Bean()
    public SqlSessionFactoryBean sqlSessionFactory(@Autowired DataSource darrSource)  {
        SqlSessionFactoryBean sqlSessionFactoryBuilder = new SqlSessionFactoryBean();
        sqlSessionFactoryBuilder.
                setConfigLocation( new PathMatchingResourcePatternResolver().getResource("mybatis-config.xml"));

        sqlSessionFactoryBuilder.setDataSource(darrSource);
        return sqlSessionFactoryBuilder;
    }

mybatis事务使用的数据源

  //@Autowired DataSource darrSource自己寻找注入到bean
 @Bean
    public TransactionManager transactionManager(@Autowired DataSource darrSource){
        DataSourceTransactionManager transactionManager = new DataSourceTransactionManager();
        transactionManager.setDataSource(darrSource);
        return transactionManager;
    }

查看数据源源码发现每次调用数据源方法都会调用new所以导致出现问题

//每次调用都会创建新的数据源 
  @SuppressWarnings("rawtypes")
    public static DataSource createDataSource(Map properties) throws Exception {
        DruidDataSource dataSource = new DruidDataSource();
        config(dataSource, properties);
        return dataSource;
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值