mybatis 向xml中传set集合参数,foreach如何遍历
需求:在实际开发中我们使用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>