报错: org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.community.mapper.DiscussPostMapper.selectDiscussPostRows
问题:
springboot项目使用 XxxMapper接口 和 同目录下的XxxMapper.xml 时,并且没有指定XxxMapper.xml 映射文件的位置,启动项目执行对象方法时就会报以上错误。
原因:
这是因为我们将 XxxMapper.xml 映射文件定义在了 src.main.java 目录下,而不是 resources 目录下,这样在编译的时候是不会将 src.main.java 目录下 XxxMapper.xml 映射文件编译到 target 目录中,那么程序在执行过程中去 target 目录中找寻需要的文件时,就会找不到,进而报以上错误。
解决办法:
首先排除 mapper.java 和 mapper.xml 文件之间的定义、关联问题。
比如:
1.是否在XxxMapper.java文件上使用了注解@Mapper 或者 在启动类上扫描了Mapper类 @MapperScan(“com.zsh.mapper”)
2.XxxMapper.xml文件中的namespace是否正确指向到XxxMapper.java类的位置 【】
3.注意被调用的方法名在XxxMapper.java中和XxxMapper.xml中的id保持一致性
4.注意XxxMapper.java在被调用的地方需要注入 @Autowired
1、pom.xml
在pom文件中:
1)如果没有手动在 <build></build>
标签中指定 <resources></resources>
使特定文件编译到target中,springboot项目默认会将 src/main/resources 目录下的文件编译到target中;
2)如果在pom文件中以 <resources></resources>
的形式在 <build></build>
标签里手动指定了 src/main/resources 目录以外的文件,则需要我们再手动指定一下 src/main/resources
目录下的文件,否则不会将src/main/resources
目录下的文件编译到target中。
现在,我们需要将 src/main/main
目录下的 .xml文件 编译到target中,需要在pom文件中增加一下代码
<build>
<resources>
<!-- src/main/resources目录下的所有文件 -->
<resource>
<directory>src/main/resources</directory>
</resource>
<!-- src/main/java目录下的xml文件,也就是我们需要的 XxxMapper.xml 映射文件 -->
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.xml</include>
</includes>
<filtering>true</filtering>
</resource>
</resources>
</build>
2、在application.properties 或 application.yaml 指定mybatis映射文件的classpath
mybatis:
mapper-locations: classpath:com/community/mapper/**/*.xml