优雅的解决Springboot:BindingException: Invalid bound statement (not found):异常

开门见山,我们先把bug贴齐全:

在这里插入图片描述

接着来说说这个bug是什么意思:

你的Mapper实例在找对应的Mapper.xml映射时没有找到

于是自然而然的,我们把问题定位在了Mapper.xml没找到,在Springboot项目中,项目结构很简单,我们一般会进行如下配置:


application.properties

mybatis.mapper-locations=classpath:/priv/zhengfa/mapper/*.xml

Application

@SpringBootApplication
@MapperScan("priv.zhengfa.mapper")
public class Application {

    public static void main(String[] args) {
        SpringApplication.run(Application.class,args);
    }

}

其中,mapper-locations指定了myabtis会去哪里读取mapper.xml文件,MapperScan则指定mybatis去哪里找到mapper接口然后生成代理类。

从项目结构来看,我们的配置应该是没有问题的,但是既然现在报了这个错误,那么很明显的原因就是:classpath:/priv/zhengfa/mapper/*.xml这个路径没有我的xml文件:


果然,mapper.xml没有在目标文件夹,定位到了问题,那么解决起来就简单了:

1、把mapper.xml文件放到resource文件夹下,保持同名即可

但是有些人觉得麻烦,我就希望Mapper接口类和XML文件放在一起, 一目了然,这时候该怎么做呢?

2、在pom文件中加入如下配置即可:

<build>
    <resources>
        <resource>
            <directory>src/main/java</directory>
            <includes>
                <include>**/*.xml</include>
            </includes>
        </resource>
    </resources>
</build>
  • 16
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值