Springboot多模块项目集成mybatis-plus报错之Invalid bound statement (not found)-SqlSessionFactory

背景

有一个项目集成了mybatis-plus,是基于springboot的多模块项目做的,新写了xml后发现报了这个错 Invalid bound statement (not found), 就是mapper接口和mapper.xml没有映射起来,接着开始按照下面步骤排查原因。

排查步骤

  1. 检查 xml 文件,namespace 命名空间是否对应mapper,经检查无误。

  1. 检查 xml 文件里面,select标签的方法名是否对应,经检查无误

  1. 检查 xml 文件存放路径是否正确,经检查存放在resources下面,无误

  1. 因为使用mybatis-plus,检查是否配置了正确的位置,检查无误,


mybatis-plus:
  mapper-locations: classpath*:mapper/*.xml

# 如果是mybatis的配置
mybatis:
  mapper-locations: classpath*:mapper/*.xml
  1. 因为是springboot多模块,怀疑有mapper覆盖,其实上一步 classpath后跟着*,就会检查所有resources目录

  1. 仍然无效,遂无奈debug找原因

Debug步骤

首先介绍mybatis组件,因为启动时会SqlSessionFactory,通过SqlSessionFactoryBean注入,(因使用mybatis-plus,使用的是MybatisSqlSessionFactoryBean)其中会缓存所有xml文件与方法。有一个方法为 buildSqlSessionFactory ,在相关加载xml文件处打断点。debug启动后遂查看,发现注入为空,没有加载进来xml文件:

推断为mapper路径的配置问题,可是已经配置了mybatis-plus的 mapper-locations,为啥没加载进来呢,找到 MybatisPlusProperties 类,其中已经默认配置了路径。

遂推断bean加载的时候问题,一通寻找发现项目中因为是多数据源配置,重写了 MybatisSqlSessionFactoryBean, 查看代码

发现为这里的问题,遂重信写了个配置文件,手动加入mapper文件位置,

重新debug,xml文件已经加载进来。

再次测试接口,接口也正常了。

至此,问题解决完毕。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Mybatis-plus的"Invalid bound statement (not found)"错误一般是因为无效的绑定语句造成的。这个错误可能有多种原因,以下是一些可能的解决方法: 1. 首先,请确保你的mapper.xml文件中有对应的SQL语句。检查mapper.xml的名称与mapper.java名称是否一致,确保XML中的SQL语句与对应的Mapper接口方法名称一致。 2. 如果你使用了Mybatis-plusSqlSessionFactory,请确保你在配置中使用了MybatisSqlSessionFactory而不是原生的SqlSessionFactory。你可以参考以下代码进行配置: ```java @Bean(name = "sqlSessionFactory") @Primary public SqlSessionFactory sqlSessionFactory(@Qualifier("dataSource") DataSource datasource) throws Exception { MybatisSqlSessionFactoryBean bean = new MybatisSqlSessionFactoryBean(); bean.setDataSource(datasource); bean.setPlugins(mybatisPlusInterceptor()); return bean.getObject(); } ``` 3. 还有可能是因为配置文件中的映射路径不正确。请仔细检查你的mapper.xml文件的路径是否正确,并确保在配置文件中正确引用了这些路径。 希望以上解决方法能够帮助你解决"Mybatis-plus Invalid bound statement (not found)"的问题。如果问题还未解决,请提供更多的具体信息以便进一步排查。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [mybatis plus 常见问题Invalid bound statement (not found)解决方法汇总](https://blog.csdn.net/zhicong1652/article/details/127475671)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [Java企业报表管理系统源码](https://download.csdn.net/download/m0_55416028/88269629)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值