在上一篇:《【已解决】Spring Boot多数据源的时候,mybatis报错提示:Invalid bound statement (not found)》 凯哥(凯哥Java) 已经接受了,在Spring Boot配置多数据源时候,因为自己马虎,导致的一个坑。下面,凯哥在介绍配置多数据源时候的坑:
模仿另一个项目的配置,但第二个数据源一直报异常:
查资料后,始终认为是配置的mapper.xml和dao的问题。但无论怎么改,都不行。
最后发现之前那个项目,第二个数据源对应的dao,都没有加@Mapper注解,遂去掉后即正常了。(可能和我将第一个数据源配置成Primary有关系?)
暂不清楚具体原因,仅此记录。
------------- 后记 -------------
经测试,果然是因为@Primary注解引起的。引起问题注解的代码如下:
@Configuration
@MapperScan(basePackages = "com.kaigejava.trade.admin.dao", sqlSessionFactoryRef = "defaultSqlSessionFactory")
public class TradeSystemConfig {
/**
* Bean 将这个对象放入Spring容器中
* Primary 表示这个数据源是默认数据源
* ConfigurationProperties 读取application.properties中的配置参数映射成为一个对象
* prefix 表示参数的前缀
*
* @return {@link DataSource}
*/
@Bean(name = "defaultDataSource")
@Primary
@ConfigurationProperties(prefix = "spring.datasource.tts")
public DataSource getDateSourceTts() {
return DataSourceBuilder.create().build();
}
/**
* 表示这个数据源是默认数据源
* Qualifier 表示查找Spring容器中名字为defaultDataSource的对象
*
* @param datasource {@link DataSource}
* @return @{link SqlSessionFactory}
* @throws Exception ex
*/
@Bean(name = "defaultSqlSessionFactory")
@Primary
public SqlSessionFactory defaultSqlSessionFactory(@Qualifier("defaultDataSource") DataSource datasource) throws Exception {
SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
org.apache.ibatis.session.Configuration configuration = new org.apache.ibatis.session.Configuration();
configuration.setMapUnderscoreToCamelCase(true);
bean.setConfiguration(configuration);
bean.setDataSource(datasource);
// 设置mybatis的xml所在位置
bean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:mapper/*.xml"));
return bean.getObject();
}
/**
* 表示这个数据源是默认数据源
*
* @param sessionFactory {@link SqlSessionFactory}
* @return {@link SqlSessionTemplate}
*/
@Bean("defaultSqlSessionTemplate")
@Primary
public SqlSessionTemplate defaultSqlSessionTemplate(
@Qualifier("defaultSqlSessionFactory") SqlSessionFactory sessionFactory) {
return new SqlSessionTemplate(sessionFactory);
}
}
可以去掉这个注解,然后Dao便可以正常写上@Mapper注解了。