概述
很多时候,你报在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的工作目录如下,其后也有相关说明,相信用多了都会知道这怎么弄的
图来源于网络编译后的工作目录:
其实,不论是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文件的
放在src/main/java路径下进行如下配置时,我们看看会发生什么?
mybatis-plus:
mapper-locations: classpath:/com/pinyou/brand/mapper/xml/*.xml
点开,target,你是看不到xml文件,如图
没有对吧,
运行一下程序,你就会看到,报错了,
为什么会这样呐?原因是在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>
看到了嘛
为此理解maven的工作目录编译目录是有好处的,有利于你排查问题
补充一点:
classpath和classpath的区别:
classpath:只会在你的class路径下寻找
classpath:不仅包含class路径,还包括jar文件中(class路径)进行查找
一般来说,在公司项目开发中都会需要用到classpath*进行文件配置,因为大型一点的公司一般会用到第三方的jar,所以大多情况下会需要查找这些jar的配置文件。