maven使用Mybatis的时候报错:org.apache.ibatis.binding.BindingException: Invalid bound statement (not found):

文章讲述了在Maven项目中使用Mybatis时遇到多表查询SQL错误,原因可能是maven默认只加载部分文件。解决方案包括将XML文件放入resources目录或通过SpringBoot插件配置指定mapper-locations来加载XML文件。
摘要由CSDN通过智能技术生成

在maven工程中使用Mybatis,因为需要多表查询,自己编写了sql语句,运行项目的时候报错:org.apache.ibatis.binding.BindingException: Invalid bound statement (not found):

问题分析:

        首先检查编写sql的xml文件中,对应的路径以及方法名是否一致,如果都一致就是因为maven加载机制导致的,默认情况下,maven只会加载项目src-main-java里面的java类型文件以及resources目录下的文件,其他文件是不会加载的

解决:

方式一:把xml文件放到resources目录下

        可以将编写sql语句的xml文件,放置到resources目录下,但是这样可能会导致更改项目中一些依赖路径,会比较麻烦,所以推荐方式二。

方式二:通过配置方式进行加载

        2.1、在项目中的pom.xml文件中添加一下配置:

<build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
        <resources>
            <resource>
                <directory>src/main/java</directory>
                <includes>
                    <include>**/*.yml</include>
                    <include>**/*.properties</include>
                    <include>**/*.xml</include>
                </includes>
                <filtering>false</filtering>
            </resource>
            <resource>
                <directory>src/main/resources</directory>
                <includes> <include>**/*.yml</include>
                    <include>**/*.properties</include>
                    <include>**/*.xml</include>
                </includes>
                <filtering>false</filtering>
            </resource>
        </resources>
    </build>

         2.2、在项目的配置文件中添加mybatis的相关配置  

mybatis-plus:
  mapper-locations: classpath:com/atguigu/auth/mapper/xml/*.xml

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值