springboot 整合mybatis 报错Invalid bound statement (not found)

springboot 整合mybatis后 报错Invalid bound statement (not found) 报错提示很明显(无效的绑定语句 找不到dao接口对应的xxxMapper.xml)

可能的原因:

1、xxxmapper.xml中的namespace未正确配置 

1.1、未在dao接口上添加@mapper注解 或者在springboot启动类上未添加包扫描的@mapperscan()注解

2.1、xxxmapper.xml放到了java目录里面。*例如下图:这样会出现一个问题,即使你在properties里面配置了 mybatis.mapper-locations= classpath:com/dao/*.xml,也没有用,因为编译的时候这个xml文件并没有被自动拉到target里面,毕竟编译的是.java文件而不是xml嘛,所以这时候应该在pom文件里面加上

 </build>
        <resources>
            <resource>
                <directory>src/main/java</directory><!--所在的目录-->
                <includes><!--包括目录下的.properties,.xml文件都会扫描到-->
                    <include>**/*.properties</include>
                    <include>**/*.xml</include>
                </includes>
                <filtering>false</filtering>
            </resource>
        </resources>
    </build>

 

2.2、如果你把xml放到了resources文件下,那么就只需要配置mybatis.mapper-locations=classpath:*/mapper/*.xml 就可以了,因为构建的时候会把resources里的东西自动拉到classpath下,注意.classpath意思就是编译后target文件夹下的classes目录.

2.3、如果你的xml文件在resources中的目录名称和dao接口的目录名称一致 可以省略application.yml中的mybatis配置

备注:配置完成后 记得maven clean && rebuild一下 查看target 下编译结果

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值