情况说明:
- 项目中本来就有一个数据源了,运行的好好的
- 后来又合并了另一个项目,另一个项目也配置了数据源。
于是出现了如下错误:
- mybatis 多数据源 TDataSource required a single bean, but 2 were found
解决方法:
-
禁用自动配置:exclude = DataSourceAutoConfiguration.class
- 重写代码配置DataSource 和mapperConfig,已经事务管理器
/**
* 创建动态数据源的SqlSessionFactory,传入的是动态数据源
* @Primary这个注解很重要,如果项目中存在多个SqlSessionFactory,这个注解一定要加上
*/
@Primary
@Bean("sqlSessionFactory2")
public SqlSessionFactory sqlSessionFactoryBean(DynamicDataSource dynamicDataSource) throws Exception {
SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();
sqlSessionFactoryBean.setDataSource(dynamicDataSource);
org.apache.ibatis.session.Configuration configuration = new org.apache.ibatis.session.Configuration();
configuration.setMapUnderscoreToCamelCase(true);
configuration.setDefaultFetchSize(100);
configuration.setDefaultStatementTimeout(30);
sqlSessionFactoryBean.setConfiguration(configuration);
return sqlSessionFactoryBean.getObject();
}
ok!