Mybatis使用IN语句查询

一、简介在SQL语法中如果我们想使用in的话直接可以像如下一样使用:

select * from HealthCoupon where useType in ( '4' , '3' )

但是如果在MyBatis中的使用in的话,像如下去做的话,肯定会报错:

    Map selectByUserId(@Param("useType") String useType)       

  •         select * from HealthCoupon where useType in (#{useType,jdbcType=VARCHAR})   
  • 其中useType="2,3";这样的写法,看似很简单,但是MyBatis不支持。。但是MyBatis中提供了foreach语句实现IN查询,foreach语法如下:

    foreach语句中, collection属性的参数类型可以使:List、数组、map集合​     collection: 必须跟mapper.java中@Param标签指定的元素名一样​     item: 表示在迭代过程中每一个元素的别名,可以随便起名,但是必须跟元素中的#{}里面的名称一样。   index:表示在迭代过程中每次迭代到的位置(下标)   open:前缀, sql语句中集合都必须用小括号()括起来​     close:后缀   separator:分隔符,表示迭代时每个元素之间以什么分隔正确的写法有以下几种写法:

    (一)、selectByIdSet(List idList)如果参数的类型是List, 则在使用时,collection属性要必须指定为 list

    List selectByIdSet(List idList); 

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

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

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

    请填写红包祝福语或标题

    红包个数最小为10个

    红包金额最低5元

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

    抵扣说明:

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

    余额充值