Mybatis Invalid bound statement (not found)排查思路

本文详细介绍了在遇到Mybatis 'Invalid bound statement (not found)' 错误时的排查过程,从问题现象到大胆猜测,再到小心求证。作者通过对比main调试和jar包调试发现Mapper注入的数据源不一致。进一步分析发现,这是由于项目中多个spring配置文件导致的Mapper扫描冲突。修复这个问题,只需调整配置文件中Mapper扫描的basePackage,避免重复扫描。
摘要由CSDN通过智能技术生成

前两天在项目中遇到个很神奇的问题,想着周末有空的时候给解一下

问题的现象

在IDEA中执行main方法能正常跑通程序
但是打包后,执行jar包会报错,错误信息如下:
org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)

是在调用Mapper方法的时候抛出的异常
image.png

大胆猜测,小心求证

此时心中隐隐有答案,猜测大概率是数据源有问题,为了求证心中所想

我在报错的地方打了个断点,在两种不同的场景下分别进行调试

main调试

查看Mapper对应的数据源信息

image.png

jar包调试

使用调试模式执行jar包,打开命令行执行下面命令

java -Xdebug -Xrunjdwp:transport=dt_socket,address=
Mybatis-plus的"Invalid bound statement (not found)"错误一般是因为无效的绑定语句造成的。这个错误可能有多种原因,以下是一些可能的解决方法: 1. 首先,请确保你的mapper.xml文件中有对应的SQL语句。检查mapper.xml的名称与mapper.java名称是否一致,确保XML中的SQL语句与对应的Mapper接口方法名称一致。 2. 如果你使用了Mybatis-plus的SqlSessionFactory,请确保你在配置中使用了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、付费专栏及课程。

余额充值