概述

很多时候,你报在Invalid bound statement (not found):。很大程度上是有两个配置引起的,一个是@MapperScan({“com.pinyougou.**.mapper”}),你忘在启动类上加,或者不加都会报Invalid bound statement (not found),

你要使用xml文件,必须要在application.yml中配置xml文件的路径,而xml的路径,即可以可放在src/main/java目录下,也可以放在src/main/resources目录下,放在src/main/resources直接配xml位置就可以了,如果放在src/main/java,则不仅要配置xml位置,还要在pom文件中更改配置,让maven在打包的时候把xml文件打包进classes文件夹中

maven目录说明

maven的工作目录如下,其后也有相关说明,相信用多了都会知道这怎么弄的

java mapper内置操作_java mapper内置操作


图来源于网络编译后的工作目录:

java mapper内置操作_xml_02


其实,不论是src/main/java还是在src/main/resources下的文件都会输出到target的classes目录下,但是它们会分别保存到两个目录下,比如src/main/java下的com保存为了target的com,而src/main/resources下的xml,保存为了target的xml。而com中主要保存的是你类的class文件,而xml是你放在resources下的文件。

mybatis-plus的xml文件路径配置

放在src/main/resources路径下需要进行如下配置:

mybatis-plus:
  mapper-locations: classpath:/xml/*.xml

即mapper-locations: classpath:文件路径名

如下图,你是可以在target中看到,xml文件的

java mapper内置操作_xml_03

放在src/main/java路径下进行如下配置时,我们看看会发生什么?

mybatis-plus:
  mapper-locations: classpath:/com/pinyou/brand/mapper/xml/*.xml

java mapper内置操作_java mapper内置操作_04


点开,target,你是看不到xml文件,如图

java mapper内置操作_xml文件_05

没有对吧,

运行一下程序,你就会看到,报错了,

java mapper内置操作_xml文件_06

为什么会这样呐?原因是在maven默认情况下是不会将src/main/java目录的xml等资源打包进入class文件夹的,而是直接忽略掉。

怎么办呐?

在pom中加入如下配置,告诉idea,在编译的时候将src/main/java下的xml一起打包进class文件夹中,这样也就不会报Invalid bound statement (not found)错误了

<build>
        <resources>
            <resource>
                <directory>src/main/java</directory>
                <includes>
                    <include>**/*.xml</include>
                </includes>
            </resource>
        </resources>
    </build>

看到了嘛

java mapper内置操作_java mapper内置操作_07

为此理解maven的工作目录编译目录是有好处的,有利于你排查问题

补充一点:
classpath和classpath的区别:
classpath:只会在你的class路径下寻找
classpath
:不仅包含class路径,还包括jar文件中(class路径)进行查找

一般来说,在公司项目开发中都会需要用到classpath*进行文件配置,因为大型一点的公司一般会用到第三方的jar,所以大多情况下会需要查找这些jar的配置文件。