SpringBoot /MyBatis 报Invalid bound statement (not found)错误

本文记录了在使用SpringBoot和MyBatis时遇到的'Invalid bound statement (not found)'错误的解决过程,包括检查XML文件包名、Mapper接口、命名空间和方法名称,以及排查application.yml中MyBatis配置,并通过maven清洁和安装来解决问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近在练习Git上面一个挺好的项目,mall-learning。运行的时候碰到这个问题,做个记录。

1.直接上报错的图片
在这里插入图片描述
1:检查xml文件所在package名称是否和Mapper interface所在的包名一一对应;
2:检查xml的namespace是否和xml文件的package名称一一对应;
3:检查方法名称是否对应;

package com.macro.mall.tiny.dao;

import com.macro.mall.tiny.mbg.model.UmsPermission;
import org.apache.ibatis.annotations.Param;
import org.springframework.stereotype.Component;

import java.util.List;

/**
 * 后台用户与角色管理自定义Dao
 * @author zgku
 * @version 1.0
 * @date 2020/5/9 10:49
 */

@Component
public interface UmsAdminRoleRelationDao {
    /**
     * 获取用户所有权限(包括+-权限)
     */
    List<UmsPermission> getPermissionList(@Param("adminId") Long adminId);
}

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.macro.mall.tiny.dao.UmsAdminRoleRelationDao">
    <select id="getPermissionList" resultMap="com.macro.mall.tiny.mbg.mapper.UmsPermissionMapper.BaseResultMap">

我仔细检查了好几遍都没问题还是报错。
换个思路,
4.看下application.yml里面MyBatis的配置有没有问题

server:
  port: 8080
spring:

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

这里注意一下,mybatis跟spring是同级的,前面一定不要有空格或者缩进。
检查后也没有问题。
最后没办法,只能先maven-clean 再maven-install 一下。
在这里插入图片描述
项目重新启动后,到swagger-ui测试一下,
在这里插入图片描述
返回的是200.竟然成功了,没报错.
测试Controller,控制台输出正常。

2020-05-11 16:11:41.702  INFO 928 --- [nio-8080-exec-3] c.m.m.t.c.JwtAuthenticationTokenFilter   : checking username:test
2020-05-11 16:11:41.707  INFO 928 --- [nio-8080-exec-3] c.m.m.t.c.JwtAuthenticationTokenFilter   : authenticated user:test

以上。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值