报错信息如下: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); // 连接池大小,默认10
ds.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); // 连接池大小,默认10
ds.setConnectionTimeout(60000); // 等待来自池的连接的最大毫秒数,默认30秒
return ds;
}
// 创建事务管理器
@Bean(name = "transactionManager")
public PlatformTransactionManager txManager(@Qualifier("dataSource") DataSource dataSource) {
return new DataSourceTransactionManager(dataSource);
}
}
2.在原添加事务(@Transactional)处指定事务管理器
@Transactional(transactionManager = "transactionManager")
以上两步,解决了我的问题,在此记录一下,大家可以适当参考。