在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