Mybatis中mapper.xml文件无法编译到target目录下的问题

报错: 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

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值