Mybatis--foreach标签属性介绍及使用

foreach属性介绍

foreach用来迭代传过来的参数。
foreach标签的主要属性有item,index,collection,open,separator,close。

  • collection:表示传入过来的参数的数据类型。该参数为必选。要做 foreach 的对象,作为入参时,List 对象默认用 list 代替作为键,数组对象有 array 代替作为键,Map 对象没有默认的键。当然在作为入参时可以使用 @Param(“keyName”) 来设置键,设置 keyName 后,list,array 将会失效。 除了入参这种情况外,还有一种作为参数对象的某个字段的时候。举个例子:
    • 如果 User 有属性 List ids。入参是 User 对象,那么这个 collection = “ids” 如果 User 有属性 Ids ids;其中 Ids 是个对象,Ids 有个属性 List id;入参是 User 对象,那么 collection = “ids.id”
    • 如果传入的是单参数且参数类型是一个 List 的时候,collection 属性值默认为 list
    • 如果传入的是单参数且参数类型是一个 array 数组的时候,collection 的属性值默认为 array
    • 如果传入的参数是多个的时候,我们就需要把它们封装成一个 Map 了,当然单参数也可以封装成 map。
  • item: 循环体中的具体对象。支持属性的点路径访问,如 item.age,item.info.details。具体说明:在 list 和数组中是其中的对象,在 map 中是 value,该参数为必选。(它是每一个元素进行迭代时的别名)
  • index:在 list 和数组中,index 是元素的序号;在 map 中,index 是元素的 key。
  • open:表示该语句以什么开始
  • close:表示该语句以什么结束
  • separator:表示在每次进行迭代之间以什么符号作为分隔符
 <select id="getnoinlist" resultType="com.work.webstudy.Pojo.StudyList">
    select *
    from study_list
    where id not in
    <!-- collection是参数数据类型, item是下列循环的具体对象 ,index是遍历的序号-->
     <!-- open 是加在开头,separator是加在每个遍历的数据间的字符,close是加在结尾-->
    <foreach collection="list" item="l" index="index" separator=","  open="("  close=")">
      #{l}
    </foreach>
  </select>
  • 5
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatis-Plus 提供了 `foreach` 标签,用于在 SQL 中动态生成 `IN`、`VALUES`、`SET` 等语句。以下是 `foreach` 的使用方法: 1. 在 XML 中使用 `foreach` 标签 ```xml <select id="selectByIdList" resultType="com.example.entity.User"> SELECT * FROM user WHERE id IN <foreach collection="idList" item="id" open="(" separator="," close=")"> #{id} </foreach> </select> ``` 2. 在注解中使用 `@foreach` 注解 ```java @Select("SELECT * FROM user WHERE id IN " + "<foreach collection='idList' item='id' open='(' separator=',' close=')'>" + "#{id}" + "</foreach>") List<User> selectByIdList(@Param("idList") List<Long> idList); ``` 以上两种方式的效果相同,都是根据传入的 `idList` 生成 `IN` 语句。 `foreach` 标签属性说明: - `collection`:需要遍历的集合或数组。 - `item`:遍历集合或数组时,当前元素的别名。 - `open`:遍历集合或数组时,生成 SQL 语句的开头。 - `separator`:遍历集合或数组时,生成 SQL 语句的分隔符。 - `close`:遍历集合或数组时,生成 SQL 语句的结尾。 - `index`:遍历集合或数组时,当前元素的下标。 - `javaType`:遍历集合或数组时,当前元素的类型。 - `jdbcType`:遍历集合或数组时,当前元素在 SQL 中的类型。 - `property`:遍历集合或数组时,当前元素的属性名。适用于对象集合或数组。 注意事项: - `collection` 属性可以使用 OGNL 表达式,例如 `collection="#{userList}"`。 - 如果遍历的是对象集合或数组,可以使用 `property` 指定当前元素的属性名。 - 如果集合或数组中的元素是简单类型(如 int、String),可以省略 `javaType` 和 `jdbcType` 属性。如果是复杂类型(如 Date、BigDecimal),需要指定 `javaType` 和 `jdbcType`。 - `foreach` 中可以嵌套 `if`、`where`、`set` 等标签,以实现更复杂的 SQL 生成。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值