ibatis.binding.BindingException: Invalid bound statement (not found)

本文介绍了解决MyBatis中Mapper XML配置错误的方法,包括调整配置路径和确保资源文件正确包含。针对两种常见场景提供了具体解决方案。

前提:

第一种情况:

1.1  mybatis的xml文件在resources/mapper路径下:

1.2  application.yml中mybatis相关配置如下:

 

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

于是程序启动一旦调用数据库查询就出现了如下问题:

ibatis.binding.BindingException: Invalid bound statement (not found) 

意思是mapper.java找不到对应的mapper.xml

别人的回答都是抄,所有的回答基本全TM一个样!

解决问题还是要靠自己!

查看target:

你会发现编译后的mapper.xml路径中,resources不见了,所以,把

 

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

改为:

 

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

问题解决!

解决这个问题最重要的途径是看你的target中有没有这个.xml文件或其路径对不对!

 

2. 另一种情况是,把mapper.xml和mapper.java都放到package中的情况:

在target里面没有看到mapper.xml文件,如下图:

正常情况下,应该是有mapper.xml文件才对,因此,发现在pom文件里面没有做响应的配置:

<build>
		<resources>
			<resource>
				<directory>src/main/resources</directory>
				<includes>
					<include>**/*.properties</include>
					<include>**/*.xml</include>
					<include>**/*.yaml</include>
					<include>**/*.json</include>
					<include>**/**</include>
				</includes>
            </resource>
            <resource>
				<directory>src/main/resources</directory>
				<includes>
                    <include>**/*.woff</include>
                    <include>**/*.woff2</include>
                    <include>**/*.ttf</include>
                </includes>
				<filtering>false</filtering>
			</resource>
			<resource>
				<directory>src/main/java</directory>
				<includes>
					<include>**/*.xml</include>
				</includes>
				<!-- 是否替换资源中的属性 -->
				<filtering>false</filtering>
			</resource>
		</resources>
<build>

加上之后,将target文件夹删除,再编译一下module,就有了:

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值