在上一篇:《【已解决】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注解了。