mybatis,foreach,找不到参数报错问题及解决
作者:法国锄头雨
这篇文章主要介绍了mybatis,foreach,找不到参数报错问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
mybatis,foreach,找不到参数报错
Resolved [org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.
#{} 内部名字要和 item 的名字一致
解决接口传入List或数组后,mybatis找不到参数报错
废话少说,上代码,接口原来写成了:
List<BugCcDO> getBugCcs(Long[] workIds);
mapper文件配置:
<select id="getBugCcs" resultType="com.changhong.cloud.tmplatform.entity.bug.BugCcDO"> SELECT <include refid="All_CcLog_Column_Values"/> FROM pms_cc_log WHERE <if test="workIds != null"> work_id IN <foreach item="workId" index="index" collection="workIds" open="(" separator="," close=")"> #{workId} </foreach> </if> </select>
然后一直报错:
org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.binding.BindingException: Parameter 'workIds' not found. Available parameters are [array]
找到的解决方法是:
修改接口传参为:
List<BugCcDO> getBugCcs(@Param("workIds") Long[] workIds);
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。