org.apache.ibatis.binding.BindingException: Invalid bound statement (not found) 错误 [已解决]

前言

  • 在使用 MyBatis 进行数据库操作时,经常会遇到 org.apache.ibatis.binding.BindingException: Invalid bound statement (not found) 错误。这个错误通常表示 MyBatis 无法找到指定的映射文件(XML 文件),这可能是由于多种原因造成的。本文将详细介绍如何解决这个问题。

常见原因及解决方法

1. XML 文件未被打包进 JAR 文件

  • 这是最常见的原因之一。如果你使用 Maven 进行项目构建,确保 XML 文件被正确打包进 JAR 文件中。

1.1 检查 pom.xml 中的资源配置

<build>
    <resources>
	    <resource>
	        <directory>src/main/resources</directory>
	        <filtering>true</filtering>
	    </resource>
	    <resource>
	        <directory>src/main/java</directory>
	        <includes>
	            <include>**/*.xml</include>
	        </includes>
	    </resource>
    </resources>
    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-jar-plugin</artifactId>
            <version>3.2.0</version>
            <configuration>
                <archive>
                    <manifest>
                        <addClasspath>true</addClasspath>
                        <classpathPrefix>lib/</classpathPrefix>
                        <mainClass>com.yourcompany.yourapp.MainClass</mainClass>
                    </manifest>
                </archive>
            </configuration>
        </plugin>
    </plugins>
</build>

1.2 确保文件路径正确

  • 确保你的 XML 文件位于 src/main/java 目录下。例如,如果你有一个 mapper.xml 文件,它应该位于:
src/main/java/mapper.xml

1.3 清理和重新构建项目

mvn clean install

总结

  • 通过以上步骤,你应该能够解决 org.apache.ibatis.binding.BindingException: Invalid bound statement (not found) 错误。主要的检查点包括:
    1、确保 XML 文件被正确打包进 JAR 文件中。
    2、确保 XML 文件的命名和路径与 Mapper 接口中的命名空间一致。
    3、确保 MyBatis 配置文件中正确引用了 Mapper XML 文件。
    4、确保项目类路径中包含所有的资源文件。

总结

如果此篇文章有帮助到您, 希望打大佬们能关注点赞收藏评论支持一波,非常感谢大家!
如果有不对的地方请指正!!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lfwh

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值