mybatis 批量增加 Parameter '__frch_item_0' not found. Available parameters are [list]
2024-08-30 04:40:15
当在mybatis用到foreach的时候,会报这个错误Parameter '__frch_item_0' not found. Available parameters are [list]会出现的几种解决方案
例子
- <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也就不存在。
最新文章
- Nginx使用Expires增加浏览器缓存加速
- 给groupBox添加滚动条
- 利用curl抓取远程页面内容
- 如果你只会JQuery的插件式开发, 那么你可以进来看看?
- App Thinning
- 让<;未将对象引用到实例>;见鬼去吧!
- 【Tcpcopy】离线回放功能
- Android Fragment类方法
- 03-树2. Tree Traversals Again (25)
- 移动并改变alpha
- thinkphp 3.2.3 入门示例
- DHot.exe 热点新闻
- Android图片加载库Fresco
- 【推荐】 HyperLedger Fabric环境搭建、测试及注意事项 [详尽指导] [亲测有效]
- ultiple Endpoints may not be deployed to the same path
- linux 修改普通用户的 max user process
- Emoji表情编解码库XXL-EMOJI
- postman管理收藏夹,批量执行接口
- window下nodejs用nodemon启动koa2项目(用cmd启动不了,要用Git Bash Here 启动才可以)
- z-index注意事项