zoukankan      html  css  js  c++  java
  • 解决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

    这个很容易被忽略,一次SpringBoot中使用MyBatis时我调了半天,其它可能性都被排除了,愣是找不到原因,最后发现是我创建映射文件时直接输入UserDaoMapper,没带后缀.xml。

    你不带后缀.xml,IDEA根据文件内容能识别它是xml文件,显示的图标也是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更新输出目录下的资源文件。
  • 相关阅读:
    Pycharm中运行Python代码的几种方式
    Git同步Python代码
    抓包工具Charles的使用
    jmeter进行的接口测试和压力测试
    并发的HTTP请求,apache是如何响应的,以及如何调用php文件的
    http 请求头部解析
    display_errors","On");和error_reporting 区别和联系
    http
    curl
    正则 惰性和非惰性匹配
  • 原文地址:https://www.cnblogs.com/chy18883701161/p/12695356.html
Copyright © 2011-2022 走看看