mybatis 批量增长 Parameter '__frch_item_0' not found. Available parameters are [list]

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

例子mysql

 

[sql] view plaincopysql

  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里面的值有没有传递进来 mybatis

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

4.还有就是我用Mybatis的时候,用MySQL的值插入自动增加值,里面的key我在数据库中没有设置自动增加,而后我又用了selectkey,因此也会出现这种状况url

--------------------------------------------------------------------spa

还有一种状况是item的属性不对,我在使用通用Map的时候,发现此问题。.net

通用Map的好处是减小了对Bean的书写,问题是若是数据库的查询结果为Null,对应属性的key也就不存在

相关文章
相关标签/搜索