欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 编程资源 > 编程问答 >内容正文

编程问答

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

发布时间:2025/3/21 编程问答 32 豆豆
生活随笔 收集整理的这篇文章主要介绍了 mybatis 批量增加 Parameter '__frch_item_0' not found. Available parameters are [list] 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

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

例子

 

[sql] view plaincopy
  •   <insert id="insertBatchPicAttachment"  parameterType="java.util.List">  
  •        insert into pic_attachment   
  •           (pic_id,pic_udid,relate_id,relate_code,relate_code_dtl,pic_name,pic_url,pic_remote_url)   
  •        values  
  •        <foreach collection="list"  item="item" index="index" separator=",">  
  •           (#{item.picId},#{item.picUdid},#{item.relateId},#{item.relateCode},#{item.relateCodeDtl},#{item.picName},#{item.picUrl},#{item.picRemoteUrl})  
  •        </foreach>      
  •        <selectKey resultType="java.lang.Integer" order="AFTER" keyProperty="picId">  
  •             select LAST_INSERT_ID();  
  •        </selectKey>   
  •     </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,所以也会出现这种情况

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

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

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

    总结

    以上是生活随笔为你收集整理的mybatis 批量增加 Parameter '__frch_item_0' not found. Available parameters are [list]的全部内容,希望文章能够帮你解决所遇到的问题。

    如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。