需求:在实际开发中我们使用list进行范围查询,使用List集合存储范围查询数据时,可能会存在重复的数据,自然而然,我们就想到用set集合来进行存储了。
但是,我们使用set集合来做mapper的参数,如:
当我们使用set集合是,foreach会使用什么值来代替set集合呢?
<select id="findNameAndPhoneByPersonId" >
SELECT IDENTITY_NAME, USER_PHONE
FROM PERSON
WHERE PERSON_ID IN
<foreach collection="list" index="index" item="item" 错误
open="(" separator="," close=")">
#{item}
</foreach>
AND DEL_FLAG=0
</select>
collection:改成list 会抛出找不到list参数
改成set,其参数名.....,都是会抛出找不到set参数
通过看源码:
private Object wrapCollection(Object object) {
DefaultSqlSession.StrictMap map;
if (object instanceof Collection) {
map = new DefaultSqlSession.StrictMap();
map.put("collection", object);
if (object instanceof List) {
map.put("list", object);
}
return map;
} else if (object != null && object.getClass().isArray()) {
map = new DefaultSqlSession.StrictMap();
map.put("array", object);
return map;
} else {
return object;
}
}
这里明显就表明:
传入参数为list集合时 : collection = "list"
传入参数为array集合时 : collection = "array"
传入参数为其他集合时 : collection = "collection"
显而易见,将collection改为"collection"即可
<foreach collection="collection" index="index" item="item" 正确
open="(" separator="," close=")">
#{item}
</foreach>