mybatis循环对象作为参数并且对象中包含列表数据如何使用foreach

作为参数查询的实体类 里面存在一个String类型的集合

 具体业务一个实体类作为查询参数 并且需要判断如果实体类里面的字段内容不为空就拼接查询操作

 此处用到的mybatis的包含语句  

此处只需要注意的是foreach中的collection字段 在使用单个参数 的时候可以直接指定类型

集合数据参数为 list

public List dynamicForeachTest(List ids);

       <foreach collection="list" index="index" item="item" open="(" separator="," close=")">
4                #{item}       
5        </foreach>

数组则对应array:

public List dynamicForeach2Test(int[] ids);

    <foreach collection="array" index="index" item="item" open="(" separator="," close=")">
4          #{item}
5     </foreach>

如果数组或者集合是存在实体类中的一个变量或者是存在map中的一个value时

collection的取值则为实体类中的变量名称或者map中的key

集合可以使用.size()判断是否为空来实现mybatis动态sql的效果

            <if test="types != null  and types.size() > 0 "> and b1.typeId IN
                <foreach collection="types" item="id" index="index" open="(" separator="," close=")">
                    #{id}
                </foreach>
             </if>

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值