mybatis 批量增加 Parameter '__frch_item_0' not found. Available parameters are [lis
2016-03-10 16:05
543 查看
当在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也就不存在。
http://blog.csdn.net/zljjava/article/details/47038035
例子
[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也就不存在。
http://blog.csdn.net/zljjava/article/details/47038035
相关文章推荐
- 开源IMDG之GridGain
- maven install时报错Failed to execute goal org.apache.maven.plugins:maven-compiler-p
- 内存管理(retain,assign,copy,strong,weak)
- (转)清理AIX的/var文件系统大小
- AIX下如何根据端口号查找相应的进程
- AIX下tar解包问题
- AIX碎碎念
- Fatal error: Call to undefined function bindtextdomain()
- LeetCode "Palindrome Pairs"
- Codeforces Round #345 (Div. 2)-B. Beautiful Paintings(暴力)
- 如何利用sendmail发送外部邮件?
- Error: Cannot retrieve metalink for repository: epel. Please verify its path and try again
- 初学MCMC(Markov Chain Monte Carlo)
- 初学MCMC(Markov Chain Monte Carlo)
- Genymotion问题二 Initialize Engine: failed
- 开发错误记录2 .MainActivity (server)' ~ Channel is unrecoverably broken and will be disposed!
- AIR客户端-高效处理图片缩略图的解决思路2
- 1014. Waiting in Line (30)
- 解决Linux搭建sftp出现Write failed:Broken pipe的问题
- highchairts柱状图显示数值并且带单位