MyBatis关于 foreach的一些用法和大坑,绝对有效

之前我也是不会这个方面的知识,在经过百度和大神指导后终于了解了一点,废话不多说,上代码。

@Select("<script> SELECT RoleID,ObjectID,Type FROM Base_Role_Authorize where RoleID IN <foreach collection=\"list\" item=\"RoleIDs\" index=\"index\" open=\"(\" close=\")\" separator=\",\"> #{RoleIDs} </foreach> </script>")
List<MemberAuthorize> getMemberAuthorizes(Pagination page,List<String> RoleIDs);

我这里采用的是注解的形式,用的架构是springBoot
分页采用的是MyBatisPlus的分页,直接用Pagination会自动帮你分页
但是要注意一点,因为foreach在注解形式的查询语句中,会出现很多转义符,所以需要用标签
要是没有加的话,会报错的。

collection :collection属性的值有三个分别是list、array、map三种,分别对应的参数类型为:List、数组、map集合,我在上面传的参数为数组,所以值为array
    item : 表示在迭代过程中每一个元素的别名
    index :表示在迭代过程中每次迭代到的位置(下标)
    open :前缀
    close :后缀
    separator :分隔符,表示迭代时每个元素之间以什么分隔
foreach标签主要用于构建in条件,他可以在sql中对集合进行迭代。如下:

<delete id="deleteBatch"> 
    delete from user where id in
    <foreach collection="array" item="id" index="index" open="(" close=")" separator=",">
      #{id}
    </foreach>
  </delete>

这是xml文件形式的foreach

希望会对大家有帮助

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值