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);
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Spring Boot 2.6.x整合Swagger启动失败报错问题的完美解决办法
这篇文章主要给大家介绍了关于Spring Boot 2.6.x整合Swagger启动失败报错问题的完美解决办法,文中通过实例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下2022-03-03
最新评论