当前位置:   article > 正文

Mapped Statements collection does not contain value for xxx

mapped statements collection does not contain value for

说个同事出现的问题:Mapped Statements collection does not contain value for xxx

当时第一反应,就是sql文件中没有定义id为“xxx”,查看sql文件,确实定义了。(因为项目设计问题,namespace问题可以忽略)

后面就奇怪了,这个名为“xxx”的ID是一个公共方法,经过测试,其他接口的方法都可以正常调用,唯独同事写的方法不行,一道这里调用sql就抛这个错误。然后查询,说法基本一致:namespace/映射文件与接口不一致等。直接排除网上说的这种情况。

然后耐心比对同事和别人调用公共sql的地方,突然发现,这位仁兄没有调用dao层公共方法,而是自己写了一个。。。而且,接收的对象,也是sql中resultMap的对象也完全不一致。。。。好吧,问题找到了。

此文目的:使用mybatis,当抛出“Mapped Statements collection does not contain value for xxx”的时候,不仅要看网上分析出的其他原因,还要看返回对象能否与接收对象对应起来。

附录:抛错时,相关主要代码

sql
  1. <select id="querylastInfo" resultMap="reMap" parameterType="java.lang.String">
  2.     select * from (
  3.         select t.*
  4.         from table_a t
  5.        where t.flag= '${_parameter}'
  6.        order by t.ROW_ID desc)
  7.     where rownum=1
  8. </select>
  9. <resultMap id="reMap" type="resultBean">
  10.     <result property="rowId" column="ROW_ID" />
  11.     <result property="infoType" column="INFO_TYPE"/>
  12. </resultMap>

mybatis.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">
  3. <configuration>
  4.     <typeAliases>
  5.         <typeAlias alias="reMap" type="com.bean.ResultBean" />
  6.     </typeAliases>
  7.     <mappers>
  8.         <mapper resource="sqlmap/info.xml" />
  9.     </mappers>
  10. </configuration>

公用dao

ResultBean bean = this.sqlSession.selectOne("querylastInfo", "1");

同事写的:

同事 dao

ResultBeanA aBean = this.sqlSession.selectOne("querylastInfo", "1"); 

换个对象接收,编译不报错,允许也不会明显报出对象不对的错误。以后注意有公用的方法就别自己单独写。查问题要仔细,一个个单词的去对比。
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小小林熬夜学编程/article/detail/155955?site
推荐阅读
相关标签
  

闽ICP备14008679号