解决 “Invalid bound statement (not found)” 错误的五种方法springboot mybatis

BindingException:Invalid bound statement (not found) 表达的意思就是找不着而已,至于为啥找不到看你的悟性和细心程度了,,,

//@Mapper 这里一直多了一个mapper NB!!!
在这里插入图片描述

一 背景介绍 记录一下mybatis常见的错误 省的百度

https://developer.baidu.com/article/detail.html?id=2767063

在使用MyBatis或Spring JDBC进行数据库操作时,你可能会遇到BindingException:Invalid bound statement (not found)异常。这个异常通常意味着MyBatis无法找到对应的SQL语句映射。下面是一些解决这个问题的建议:

检查映射文件或注解:请确保你的MyBatis映射文件或注解配置正确。映射文件应该包含正确的namespace和statement ID,并且与你的SQL语句相匹配。同时,请确保你的XML映射文件或注解在正确的位置,并且被正确地加载到了MyBatis配置中。
检查SQL语句:请确保你的SQL语句没有语法错误,并且可以被正确地执行。你可以直接在数据库中运行SQL语句,以验证其正确性。
检查MyBatis配置:请确保你的MyBatis配置正确,包括数据源、事务管理器和其他相关配置。你可以检查MyBatis的配置文件(如mybatis-config.xml)和Spring的配置文件(如applicationContext.xml),以确保它们被正确地配置。
检查依赖:请确保你的项目中包含了所有必要的依赖,包括MyBatis和数据库驱动程序。如果你使用Maven或Gradle等构建工具,请检查你的pom.xml或build.gradle文件,以确保所有依赖都被正确地添加。
清理和重建项目:有时候,IDE或构建工具可能会出现问题,导致一些旧的或无效的类或资源没有被正确地清理掉。尝试清理你的项目并重新构建它,以确保所有的资源都被正确地加载。
查找是否有冲突的映射:如果你的项目中使用了多个MyBatis实例或映射文件,可能会出现冲突。请检查你的项目结构,并确保没有其他映射文件与你正在使用的映射文件产生冲突。
查看日志:查看MyBatis和数据库的日志,以获取更多关于异常的详细信息。这可以帮助你更好地理解问题的原因,并提供更多线索来解决问题。
更新版本:如果你使用的是旧版本的MyBatis或相关库,尝试更新到最新版本。有时候,问题可能是由于库的bug引起的,而这些bug可能在新版本中已经被修复。
通过以上步骤,你应该能够解决BindingException:Invalid bound statement (not found)异常。如果问题仍然存在,你可能需要更深入地调查问题原因,并考虑寻求更专业的帮助。

二 第一种

解决方法文章参考:https://blog.youkuaiyun.com/qq_42145991/article/details/136854267

在开发使用MyBatis框架的项目时,我们可能会遇到 “Invalid bound statement (not found)” 的错误。这通常意味着MyBatis在尝试执行SQL语句时找不到对应的映射器(Mapper)配置。以下是五种常见的解决方法:

  1. 检查Mapper接口与Mapper.xml的命名空间是否一致
    首先,确保Mapper接口的完整类名与Mapper.xml文件中的namespace属性完全匹配。例如:

public interface UserMapper {
// 接口方法
}

对应的Mapper.xml应包含:

  1. 确保方法名与Mapper.xml中的ID标签一致
    Mapper接口中定义的方法名需要与Mapper.xml中定义的id标签相匹配。例如:

public interface UserMapper {
List findAllUsers();
}
1
2
3
对应的Mapper.xml应包含:

  1. 检查Mapper.xml是否正确构建
    确保Mapper.xml文件已正确构建到项目中。如果文件没有出现在target目录下,可能需要清理并重新构建项目:

mvn clean
mvn compile

  1. 配置文件资源过滤问题
    如果配置文件没有被正确导出,可能是因为资源过滤设置不正确。在Maven的pom.xml文件中配置资源过滤,确保Java目录下的XML和properties文件能够被导出:
src/main/resources **/*.xml true src/main/java **/*.xml true
  1. 检查Spring配置文件是否正确
    最后,检查Spring配置文件是否正确编写。例如,如果您使用的是MyBatis-Plus,但配置文件中写的是MyBatis的配置,这将导致配置错误。

小贴士
对于SpringBoot项目,配置文件通常使用properties或yml格式。
希望这些方法能帮助您解决 “Invalid bound statement (not found)” 的问题。如果问题依旧存在,可能需要进一步检查项目配置或寻求社区的帮助。
————————————————

                        版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

原文链接:https://blog.youkuaiyun.com/qq_29752857/article/details/140693046

第二种

Parameter index out of range (1 > number of parameters, which is 0)
一般是sql语句格式 标点符号 空格等 有问题 用consol跑一下就好了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值