mybatis-plus配置多数据源出现invalidboundstatementnotfound怎么解决

本篇内容介绍了“mybatis-plus配置多数据源出现invalid bound statement not found怎么解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

创新互联建站主要从事网站设计、做网站、网页设计、企业做网站、公司建网站等业务。立足成都服务岚县,十年网站建设经验,价格优惠、服务专业,欢迎来电咨询建站服务:18980820575

一、 环境

  1. 版本号

    <dependency>
         <groupId>com.baomidou</groupId>
         <artifactId>mybatis-plus-boot-starter</artifactId>
         <version>3.2.0</version>
    </dependency>

  2. 没有使用myabtis-plus的多数据源依赖

    <dependency>
        <groupId>com.baomidou</groupId>
        <artifactId>dynamic-datasource-spring-boot-starter</artifactId>
        <version>2.5.7</version>
    </dependency>

二、 多数据源配置

  1. 启动类配置

    @MapperScans({
            @MapperScan(basePackages = {"com.aaa.dao"}, sqlSessionFactoryRef = DatasourceConf.SESSION_FACTORY),
            @MapperScan(basePackages = {"com.bbb.dao"}, sqlSessionFactoryRef = OtherDatasourceConf.OTHER_SESSION_FACTORY)
    })

  2. 配置类

    @Configuration
    public class DatasourceConf {
        public static final String SESSION_FACTORY = "SessionFactory";
    
        @Primary
        @Bean(name = SESSION_FACTORY)
        public SqlSessionFactory dianOrderSessionFactory(MybatisProperties properties) throws Exception {
    		SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();
            sqlSessionFactoryBean.setDataSource(secondDatasource());
            //...
        }
    
        @Primary
        @Bean
        public DataSource secondDatasource() {
            return new HikariDataSource(secondHikariConfig());
        }
    
        @Bean
        @ConfigurationProperties(prefix = "spring.datasource.aaa.hikari")
        public HikariConfig secondHikariConfig() {
            return new HikariConfig();
        }
    }

    另一个数据源配置

    @Configuration
    public class OtherDatasourceConf {
        public static final String OTHER_SESSION_FACTORY = "otherSessionFactory";
    
        @Bean(name = OTHER_SESSION_FACTORY)
        public SqlSessionFactory otherSessionFactory(MybatisProperties properties) throws Exception {
    		SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();
            sqlSessionFactoryBean.setDataSource(otherDataSource());
            //....
        }
    
        @Bean
        public DataSource otherDataSource() {
            return new HikariDataSource(otherHikariConfig());
        }
    
        @Bean
        @ConfigurationProperties(prefix = "spring.datasource.hikari")
        public HikariConfig otherHikariConfig() {
            return new HikariConfig();
        }
    
    }

三、异常

mapper.xml中配置了sql的都没问题,但是使用mybatis-plus的内置函数就会报invalid bound statement (not found)异常。

四、 解决

  1. 查看MybatisPlusAutoConfiguration

    @Configuration
    @ConditionalOnClass({SqlSessionFactory.class, SqlSessionFactoryBean.class})
    @ConditionalOnSingleCandidate(DataSource.class)
    @EnableConfigurationProperties(MybatisPlusProperties.class)
    @AutoConfigureAfter(DataSourceAutoConfiguration.class)
    public class MybatisPlusAutoConfiguration implements InitializingBean {
    
        @Bean
        @ConditionalOnMissingBean
        public SqlSessionFactory sqlSessionFactory(DataSource dataSource) throws Exception {
            // TODO 使用 MybatisSqlSessionFactoryBean 而不是 SqlSessionFactoryBean
            MybatisSqlSessionFactoryBean factory = new MybatisSqlSessionFactoryBean();
            factory.setDataSource(dataSource);
    		...
            return factory.getObject();
        }
    }

  2. SqlSessionFactoryBean修改成myabtis-plus自定义的MybatisSqlSessionFactoryBean解决

  3. 注意mybatis-plus的配置需要使用MybatisPlusProperties而不是MybatisProperties

  4. 当配置类多个DataSourceMybatisPlusAutoConfiguration类就不再生效,需要手动配置

“mybatis-plus配置多数据源出现invalid bound statement not found怎么解决”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!

文章名称:mybatis-plus配置多数据源出现invalidboundstatementnotfound怎么解决
网站路径:https://www.cdcxhl.com/article16/gdoegg.html

成都网站建设公司_创新互联,为您提供网站制作全网营销推广App开发网站营销移动网站建设网站建设

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

h5响应式网站建设