org.apache.ibatis.binding.BindingException 问题排查

港控/mmm° 2022-02-01 05:47 159阅读 0赞

问题原因:在eclipse下开发的ssm框架的web项目,切换到idea下开发

在我调试代码中遇到的有以下两种情况:

  1. 接口被扫描到,但是mapper对象注入失败,或者为 null。
  2. 接口被扫描到,代理对象创建成功并注入成功的,但是调用方法时出现异常。

下面是网上查到的几种方法:

  1. 检查xml文件所在的package名称是否和interface对应的package名称一一对应
  2. 检查xml文件的namespace是否和xml文件的package名称一一对应
  3. 接口的方法名和xml文件中的SQL的id要一样
  4. 不能存在中文注释(未验证过,我遇到的不是这种问题,如果其他方法都试过没用,可以尝试一下删掉中文注释)
  5. 接口中的返回值List集合(不知道其他集合也是),那么xml里面的配置,尽量用resultMap(保证resultMap配置正确),不要用resultType
  6. 项目是maven项目,编译后的target目录不存在xml文件。以为maven默认是不编译xml文件的,所以需要在pom.xml文件的标签里加上如下内容。



    src/main/java

    */.xml



    src/main/resources

我遇到第一个问题的解决方案,是在spring整合mybatis的配置文件中的SqlSessionFactory配置文件中指定 mapperLocations 。也就指定mapper.xml文件的位置。

20190513163835172.png

第二个问题就是maven不编译xml文件的问题,也就是上面的第六种情况。在pom中加上如上配置之后重启项目即可。

发表评论

表情:
评论列表 (有 0 条评论,159人围观)

还没有评论,来说两句吧...

相关阅读

    相关 jvm问题排查

    合threaddump(jstack ),heapdump(jmap和jhat或mat ),gc日志进行问题分析 cpu过高,top找出过高进程,top -Hp pi...

    相关 Mysql 问题排查记录

    背景 项目网页打开数据很慢,于是我就去找dba查看一下是否有慢SQL。然后DBA给的反馈是MYSQL被我调挂掉了。所以访问超时,页面打不开。 发现过程 DBA 发现有