解决MyBatis报错 org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)

总结了常见的解决方式,如下

1、检查xml文件的namespace是否对应接口,要是全路径。

xml文件名不需要和接口名一致,namespace和接口全类名一致即可。

2、xml中的函数id和接口中的函数名是否对得上,参数类型、返回值类型是否对得上

3、去看输出目录中有没有xml映射文件,maven项目默认把资源文件放在src/main/resources下,默认只识别src/main/resources下的资源文件。

如果你把xml映射文件等资源文件放到src/main/java的某个目录下,识别不了,需要在pom.xml中配置一下:

复制代码
    <resources>
        <resource>
            <directory>src/main/java</directory>
            <includes>
                <include>**/*.xml</include>
                <include>**/*.properties</include>
            </includes>
            <filtering>true</filtering>
        </resource>
        <resource>
            <directory>src/main/resources</directory>
            <includes>
                <include>**/*.xml</include>
                <include>**/*.properties</include>
            </includes>
            <filtering>true</filtering>
        </resource>
    </resources>
复制代码

把资源文件的路径都写进去。

4、看一下mybatis的配置对不对

#实体类别名
mybatis.type-aliases-package=com.chy.xm_mall.model
#映射文件的位置
mybatis.mapper-locations=classpath:mapper/*.xml

5、看一下xml映射文件是否带了后缀名.xml

第二个才是正确的。

一些常用方法

  • 看输出目录有没有xml映射文件
  • 删掉输出目录,重新编译运行,因为输出目录下的资源文件可能没有更新

将来可能会出现的

xml的dtd声明要与使用的mybatis版本保持一致

<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

这是mybatis3的声明,将来如果使用更高版本的mybatis,注意dtd声明也要对应。

未验证的

  • 去掉xml文件中的中文注释
  • 随意在xml文件中加一个空格或者空行然后保存。想来这个和删除输出目录的目的一样,都是觉得删除目录的资源文件(xml映射文件)没有更新,手动修改下文件,提醒IDEA更新输出目录下的资源文件。

 

posted @   Vincent-yuan  阅读(121)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 25岁的心里话
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示