使用MyBatis进行查询操作,参数是传的一个List:xxxList,但是在执行查询的时候报错,具体日志如下:
Parameter 'xxxList' not found. Available parameters are [list]
按照错误提示修改,举一个官方案例吧
问题出在参数的命名了,所以一定要与其一致
为什么参数命名还能有错呢?非常奇葩。有一种解释是这样的:
“可以传递一个 List 实例或者数组作为参数对象传给 MyBatis。当你这么做的时 候,MyBatis 会自动将它包装在一个 Map 中,用名称在作为键。List 实例将会以“list” 作为键,而数组实例将会以“array”作为键”
所以很多人不建议这么写,而是自己组装Map,我到时不建议用这种
第一:官方文档没有传Map的例子
第二:你遇到更复杂的参数命名问题
参考文档 http://www.mybatis.org/mybatis-3/zh/dynamic-sql.html#foreach
Parameter 'xxxList' not found. Available parameters are [list]
按照错误提示修改,举一个官方案例吧
问题出在参数的命名了,所以一定要与其一致
java :
public List<Post> selectPostIn(List list);
<select id="selectPostIn" resultType="Post">
SELECT *
FROM POST P
WHERE ID in
<foreach item="item" index="index" collection="list"
open="(" separator="," close=")">
#{item}
</foreach>
</select>
为什么参数命名还能有错呢?非常奇葩。有一种解释是这样的:
“可以传递一个 List 实例或者数组作为参数对象传给 MyBatis。当你这么做的时 候,MyBatis 会自动将它包装在一个 Map 中,用名称在作为键。List 实例将会以“list” 作为键,而数组实例将会以“array”作为键”
所以很多人不建议这么写,而是自己组装Map,我到时不建议用这种
第一:官方文档没有传Map的例子
第二:你遇到更复杂的参数命名问题
参考文档 http://www.mybatis.org/mybatis-3/zh/dynamic-sql.html#foreach