• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

Mybatis的foreach循环——循环插入多条数据

武飞扬头像
徐布衣
帮助1

1 背景

数据库插入时候,一对多的关系,入参里面有一个list集合(存放多个menu_id),现在需要在插入的时候,循环这个list集合,将数据都插入到数据库中
学新通
最大的问题是,list集合是在一个对象里
学新通
这种情况要怎么在sql语句的foreach循环标签中正确的做到循环数据

2 解决

学新通
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:**表示在每次进行迭代之间以什么符号作为分隔符

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhggceia
系列文章
更多 icon
同类精品
更多 icon
继续加载