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>

  • 7
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值