HardBirch

mybatis 批量增加 Parameter ‘__frch_item_0′ not found. Available parameters are [list]

时间:17-06-29 栏目:JAVA语言-JVM虚拟机 作者:魔豆先生 评论:0 点击: 202 次

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

例子

 

[sql] view plain copy

  1.   <insert id="insertBatchPicAttachment"  parameterType="java.util.List">
  2.        insert into pic_attachment
  3.           (pic_id,pic_udid,relate_id,relate_code,relate_code_dtl,pic_name,pic_url,pic_remote_url)
  4.        values
  5.        <foreach collection="list"  item="item" index="index" separator=",">
  6.           (#{item.picId},#{item.picUdid},#{item.relateId},#{item.relateCode},#{item.relateCodeDtl},#{item.picName},#{item.picUrl},#{item.picRemoteUrl})
  7.        </foreach>
  8.        <selectKey resultType="java.lang.Integer" order="AFTER" keyProperty="picId">
  9.             select LAST_INSERT_ID();
  10.        </selectKey>
  11.     </insert>

 

 

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

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

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

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

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

mybatis 批量增加 Parameter ‘__frch_item_0′ not found. Available parameters are [list]:等您坐沙发呢!

发表评论


QQ群互动

Linux系统与内核学习群:194051772

WP建站技术学习交流群:194062106

魔豆之路QR

魔豆的Linux内核之路

魔豆的Linux内核之路

优秀工程师当看优秀书籍

优秀程序员,要看优秀书!

赞助商广告

友荐云推荐