org.apache.ibatis.binding.BindingException: Invalid bound statement (not found
时间: 2023-08-20 16:12:39 浏览: 81
引用[1]:这个错误是由于绑定异常引起的,具体错误信息是"Invalid bound statement (not found)"。[1]这种错误通常是由于mapper接口与xml文件无法正确绑定导致的。解决这个问题的方法有以下几种:
1. 检查xml文件名是否与mapper接口名一致。
2. 检查xml文件中的namespace是否与mapper接口的全类名一致。
3. 确保在主启动类上标注了@MapperScan("mapper接口所在包的全包名")或在mapper接口类上标注了@Mapper(两者不能同时使用)。
4. 检查mapper接口方法名是否与xml文件中的id属性一致。
5. 如果打包时xml文件没有自动复制到class输出目录的mapper类包下,则需要在pom文件中添加mybatis加载配置文件的配置。
6. 清除target目录,重新编译项目。
7. 在配置文件中声明xml文件的路径。
引用[3]:此外,这个错误也可能是由于maven默认加载机制造成的。maven在加载时只会编译java文件夹中的.java类型文件,而不会加载其他类型的文件。因此,如果dao层的mapper.xml文件没有被加载,就会导致这个错误。在默认情况下,maven工程中的src/main/java目录下的所有资源文件都不会发布到target目录下。[3]
综上所述,要解决这个错误,需要检查mapper接口与xml文件的绑定是否正确,并确保相关文件被正确加载和发布。
相关问题
org.apache.ibatis.binding.BindingException: Invalidbound statement (not found)
当出现org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)错误时,通常是因为MyBatis无法找到对应的SQL语句映射。
要解决这个问题,可以按照以下步骤进行排查:
1. 首先,检查一下你的Mapper.xml文件中是否存在与该错误相关的SQL语句映射。确保SQL语句的id与Mapper接口中对应方法的名称一致。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* [mybatis访问报错:org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)...](https://blog.csdn.net/weixin_34402408/article/details/86024348)[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%"]
- *2* *3* [【报错解决】org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)](https://blog.csdn.net/qq_50914927/article/details/127091350)[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 ]
org.apache.ibatis.binding.BindingException: Invalid bound statement
这个错误通常是由于MyBatis无法找到绑定的语句引起的。可能的原因有几个。首先,你可以检查异常信息中提到的具体语句是否存在于你的Mapper接口中。如果不存在,你需要确保在Mapper接口中定义了正确的方法名并且与XML文件中定义的id一致。其次,你可以检查你的XML配置文件,确保正确地引入了Mapper接口,并且路径配置正确。此外,有时候IDEA没有编译生成相应的XML文件,你可以尝试重新编译项目以确保XML文件存在于target/classes目录下。希望这些提示能够帮助你解决这个问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* [org.apache.ibatis.binding.BindingException: Invalidbound statement (not found)的解决方案和造成原因...](https://blog.csdn.net/m0_49499183/article/details/122082333)[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^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"]
- *2* *3* [解决 org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)错误](https://blog.csdn.net/weixin_43570367/article/details/103147854)[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^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"]
[ .reference_list ]