本文主要是介绍springboot事务回滚报错No qualifying bean of type ‘org.springframework.transaction.TransactionManager‘ avai,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
报错信息如下:No qualifying bean of type 'org.springframework.transaction.TransactionManager' available
经调查发现是项目配置多数据源导致的。
项目中配置多个数据源后,在使用@Transactional()注解时如果不直接指定使用的数据源,Spring就不知道具体使用哪一个事务管理器来进行事务管理了,因此需要通过某种方式来具体指定一下。可以通过使用 @Transactional(transactionManager = “xxTransactionManager”) 来进行指定。
解决办法:
1.在配置数据源的配置中,创建事务管理器。
package com.xxxx.xxxxx.core.config;import com.ibeetl.starter.BeetlTemplateCustomize;
import com.zaxxer.hikari.HikariDataSource;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.env.Environment;
import org.springframework.jdbc.datasource.DataSourceTransactionManager;
import org.springframework.transaction.PlatformTransactionManager;import javax.sql.DataSource;
import java.util.HashMap;
import java.util.Map;@Configuration
public class BeetlFrameworkConfig {@Bean(name = "dataSource")public DataSource datasource(Environment env) {HikariDataSource ds = new HikariDataSource();ds.setJdbcUrl(env.getProperty("spring.datasource.first.url"));ds.setUsername(env.getProperty("spring.datasource.first.username"));ds.setPassword(env.getProperty("spring.datasource.first.password"));ds.setDriverClassName(env.getProperty("spring.datasource.first.driver-class-name"));ds.setMaximumPoolSize(50); // 连接池大小,默认10ds.setConnectionTimeout(60000); // 等待来自池的连接的最大毫秒数,默认30秒return ds;}@Bean(name = "whmDataSource")public DataSource whmDataSource(Environment env) {HikariDataSource ds = new HikariDataSource();ds.setJdbcUrl(env.getProperty("spring.whmDataSource.second.url"));ds.setUsername(env.getProperty("spring.whmDataSource.second.username"));ds.setPassword(env.getProperty("spring.whmDataSource.second.password"));ds.setDriverClassName(env.getProperty("spring.whmDataSource.second.driver-class-name"));ds.setMaximumPoolSize(50); // 连接池大小,默认10ds.setConnectionTimeout(60000); // 等待来自池的连接的最大毫秒数,默认30秒return ds;}// 创建事务管理器@Bean(name = "transactionManager")public PlatformTransactionManager txManager(@Qualifier("dataSource") DataSource dataSource) {return new DataSourceTransactionManager(dataSource);}
}
2.在原添加事务(@Transactional)处指定事务管理器
@Transactional(transactionManager = "transactionManager")
以上两步,解决了我的问题,在此记录一下,大家可以适当参考。
这篇关于springboot事务回滚报错No qualifying bean of type ‘org.springframework.transaction.TransactionManager‘ avai的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!