情况说明:
- 项目中本来就有一个数据源了,运行的好好的
- 后来又合并了另一个项目,另一个项目也配置了数据源。
于是出现了如下错误:
- 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!