当在mybatis用到foreach的时候异常

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了当在mybatis用到foreach的时候异常相关的知识,希望对你有一定的参考价值。

当在mybatis用到foreach的时候,会报这个错误Parameter ‘__frch_item_0‘ not found. Available parameters are [list]会出现的几种解决方案

例子

 

copy
 
  < id=  parameterType=>  
  •          pic_attachment   
  •   
  •   item= = separator=>  
  •           (#{item.picId},#{item.picUdid},#{item.relateId},#{item.relateCode},#{item.relateCodeDtl},#{item.picName},#{item.picUrl},#{item.picRemoteUrl})  
  •  = keyProperty=>  
  •  LAST_INSERT_ID();  
  •        </selectKey>   
  • >  

 

 

1.查看parameterType的类型是不是java.util.List类型,如果是的话,看foreach 的collection属性是不是list,

    因为 传递一个 List 实例或者数组作为参数对象传给 MyBatis,MyBatis 会自动将它包装在一个 Map 中,用名称在作为键。List 实例将会以“list” 作为键,而数组实例将会以“array”作为键 

2.看一下foreach里面的值有没有传递进来 

3.看foreach里面的名称字段是否写错 

4.还有就是我用Mybatis的时候,用mysql的值插入自动增长值,里面的key我在数据库中没有设置自动增长,然后我又用了selectkey,所以也会出现这种情况

--------------------------------------------------------------------

还有一种情况是 通用Map的好处是减少了对Bean的书写,问题是如果数据库的查询结果为Null,对应属性的key也就不存在。

以上是关于当在mybatis用到foreach的时候异常的主要内容,如果未能解决你的问题,请参考以下文章

源码分析 Mybatis 的 foreach 为什么会出现性能问题

MyBatis 物理分页foreach 参数失效

Mybatis-延迟加载

MyBatis中的OGNL expression

mybatis中判断foreach循环最后一个

Mybatis之foreach用法----ListArrayMap三种类型遍历