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>
经验分享 程序员 微信小程序 职场和发展