spring boot 配置多数据源 踩坑 BindingException: Invalid bound statement (not found)

发布时间:2023年12月18日

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

文章来源:https://blog.csdn.net/kaizi_1992/article/details/135041458
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。