MyBatis<foreach>标签的用法

devtools/2024/9/19 18:39:58/ 标签: mybatis, tomcat, java

文章目录

  • 1. foreach 标签
  • 2. MyBatis<foreach>标签的使用
    • 2.1 批量插入
    • 2.2 批量编辑
    • 2.3 批量查询
      • 2.4 使用 foreach 遍历 map

1. foreach 标签

foreach 可以在 SQL 语句中进行迭代一个集合。foreach元素的属性主要有 item,index,collection,open,separator,close。

  • collection 指定要遍历的集合。表示传入过来的参数名。该属性是必须指定的,要做 foreach 的对象。
  • item 表示本次迭代获取的元素,若 collection 为 List、Set 或者数组,则表示其中的元素;若collection 为 map,则 item 代表 key-value 的 value,该参数为必选;
  • index 索引,index 指定一个名字,用于表示在迭代过程中,每次迭代到的位置。遍历 list 的时候 index 就是索引,遍历 map 的时候 index 表示的就是 map 的 key,item 就是 map 的 Value。
  • open 表示该语句以什么开始,该参数为可选项(Mybatis 会将该字符拼接到整体的 sql 语句之前,并且只拼接一次);
  • separator 表示在每次进行迭代之间以什么符号作为分隔符;
  • close 表示以什么结束,该参数为可选项。

2. MyBatis<foreach>标签的使用

假设我们有一个 BatchDTO 的实体类:

java">import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;@Builder(toBuilder = true)
@AllArgsConstructor
@NoArgsConstructor
@Data
public class BatchDTO {private String workspaceKey;private String planId;private String baselineState;
}

2.1 批量插入

Repository 接口中定义方法:

java">boolean batchInsert(@Param("list") List<BatchDTO> batchDTOList, @Param("tableName") String tableName);

Mybatis 中 mapper.xml 实现如下:

java">    <insert id="batchInsert" parameterType="java.util.List">insert into ${tableName} (`workspace_key`, `plan_id`, baseline_state)values<foreach collection="list" item="item" separator=",">(#{item.workspaceKey}, #{item.planId}, #{item.baselineState})</foreach></insert>

2.2 批量编辑

Repository 接口中定义方法:

java">boolean batchUpdate(@Param("planIds") List<BatchDTO> batchDTOList, @Param("tableName") String tableName);

Mybatis 中 mapper.xml 实现如下:

java">    <update id="batchUpdate">update ${tableName}set `workspace_key` = "vvv"where `plan_id` in<foreach collection="planIds" item="item" index="index" open="(" separator="," close=")">#{item.planId}</foreach></update>

2.3 批量查询

Repository 接口中定义方法:

java">List<DAO> batchSelect(@Param("planIds") List<String> planIds, @Param("tableName") String tableName);

Mybatis 中 mapper.xml 实现如下:

java">    <select id="batchSelect" resultMap="DAOMap">select * from ${tableName}where 1 = 1<if test="planIds != null and planIds.size() > 0">and `plan_id` in<foreach collection="planIds" open="(" item="planId" close=")" separator=",">#{planId}</foreach></if></select>

如果入参类型是 List<String> 类型,可以直接以字符串类型作为入参,而不用传入一个 List。具体实现如下。

Repository 接口中定义方法:

java">List<DAO> batchSelect(@Param("planIds") String planIds, @Param("tableName") String tableName);

Mybatis 中 mapper.xml 实现如下:

java">    <select id="batchSelect" resultMap="PlanBaselineStateDAOMap">select * from ${tableName}where 1 = 1<if test="planIds != null and planIds != ''">and `plan_id` in<foreach collection="planIds.split(',')" open="(" item="planId" close=")" separator=",">#{planId}</foreach></if></select>

2.4 使用 foreach 遍历 map

这里举例使用 foreach 遍历 map。使用 foreach 遍历 map 时,foreach 标签中的参数 index 表示的就是 map 的 key,item 就是 map 的 Value。

Repository 接口中定义方法:

java">boolean batchInsert(@Param("batchInsertMap") Map<String, String> batchInsertMap, @Param("tableName") String tableName);

Mybatis 中 mapper.xml 实现如下:

java">    <insert id="batchInsert" parameterType="java.util.Map">insert into ${tableName} (`workspace_key`, `plan_id`)values<foreach collection="batchInsertMap" index="key" item="value" separator=",">(#{key}, #{value})</foreach></insert>

http://www.ppmy.cn/devtools/10168.html

相关文章

Redis中的Lua脚本(五)

Lua脚本 脚本复制 复制EVALSHA命令 EVALSHA命令式所有与Lua脚本有关的命令中&#xff0c;复制操作最复杂的一个&#xff0c;因为主服务器与从服务器载入Lua脚本的情况可能有所不同&#xff0c;所以主服务器不能像复制EVAL命令、SCRIPT LOAD命令或者SCRIPT FLUSH命令那样&…

计算机网络原原理学习资料分享笔记---第一章/第四节/第五节(为有梦想的自己加油!)

第四节 计算机网络性能 第四节 计算机网络性能 第四节 计算机网络性能 1 、速率&#xff1a; 速率&#xff1a;网络单位时间内传送的数据量&#xff0c;用以描述网络传输数据的快慢。 速率基本单位&#xff1a;bit/s&#xff08;位每秒&#xff09; Kbit/s、 Mbit/s、 Gbit/…

生成计算机注册信息:硬盘,主板和CPU组合 根据计算机硬盘,主板,CPU生成注册信息

目录 一.总体说明 二.完整代码 三.逐行分析 一.总体说明 注册信息是用于识别和验证计算机的唯一标识符。在生成注册信息时,通常会包含计算机的硬盘、主板和CPU的相关信息。这些信息可以用于授权软件、管理许可证、防止盗版以及进行系统配置和维护等方面。 具体而言,注册…

PDM在Office文档中的变量映射

在PDM数据管理软件中需要在数据卡中反馈出文件的一些属性信息&#xff0c;使得用户在不打开文件的情况下可以快速了解此文件的属性信息&#xff0c;或者需要用户在创建文档时填入相应内容&#xff0c;能够自动的填充到文档中&#xff0c;所以就需要在实施的过程中在SOLIDWORKS …

Environment Modules工具

Environment Modules工具 简介 Module是一个环境变量管理工具&#xff0c;可以很好的实现开发环境的切换。 具体可以查看官网文档 安装 安装&#xff08;安装完成之后需要exit重新登录一下才会生效&#xff09; yum install -y environment-modules命令介绍 module avai…

CentOS 源码安装 pip3

今天在安装部分服务的时候&#xff0c;由于系统 CentOS 中默认带了 pip2&#xff0c;但是我的项目需要是基于 Python3 开发的&#xff0c;需要安装 pip3&#xff0c;特此将整个安装步骤记录下来。 需要安装 Python3&#xff0c;可参考 https://devlive.org/archives/wGwzd3RG 安…

古籍数字化平台中的OCR:这个平台更精准

在浩瀚的历史长河中&#xff0c;古籍作为中华民族的文化瑰宝&#xff0c;承载着无数先人的智慧与心血。然而&#xff0c;由于岁月侵蚀、保存不当等多种原因&#xff0c;许多珍贵的古籍面临损坏、失传的危机。为了守护这些无价之宝&#xff0c;云聪研发团队倾力打造了一款尖端的…

gitlab 16.2.4 恢复

新创建新gitlab&#xff0c;版本需和备份的gitlab版本一致 docker run -d -p 322:22 -p 822:80 --name gitlab_1 gitlab/gitlab-ce:16.2.4-ce.0 进入容器内部 docker exec -it c51685817e27 /bin/bash 新的环境至少运行过一次&#xff0c;sudo gitlab-ctl reconfigu…

《前端面试题》- TypeScript - TypeScript的优/缺点

问题 简述TypeScript的优/缺点 答案 优点 增强了代码的可读性和可维护性包容性&#xff0c;js可以直接改成ts&#xff0c;ts编译报错也可以生成js文件&#xff0c;兼容第三方库&#xff0c;即使不是ts编写的社区活跃&#xff0c;完全支持es6 缺点 增加学习成本增加开发成…

STM32 堆栈内存以及变量存储分布

STM32的程序存储器、数据存储器、寄存器和输入输出端口被组织在同一个4GB的线性地址空间内, 地址范围为0x0000 0000至0xFFFF FFFF。其中FLASH为ROM类型&#xff0c;储存的数据掉电不易失&#xff1b;RAM中存储的数据掉电易失。以STM32F103系列为例&#xff0c;最多有512KB的FLA…

负载均衡的原理及算法

一、定义 负载均衡&#xff08;Load Balancing&#xff09;是一种计算机网络和服务器管理技术&#xff0c;旨在分配网络流量、请求或工作负载到多个服务器或资源&#xff0c;以确保这些服务器能够高效、均匀地处理负载&#xff0c;并且能够提供更高的性能、可用性和可扩展性。…

MATLAB图像处理介绍

MATLAB图像处理介绍 MATLAB是一款功能强大的数学软件&#xff0c;广泛应用于各种科学计算和数据分析中。其中&#xff0c;MATLAB的图像处理工具箱&#xff08;Image Processing Toolbox&#xff09;为用户提供了一套完整的图像处理和分析工具&#xff0c;无论是图像的预处理、…

高斯锁表导致sql报错处理

构造锁等待场景&#xff1a; 1.打开一个新的连接会话&#xff0c;使用普通用户连接GaussDB(DWS)数据库&#xff0c;在test SCHEMA 下创建测试表test.ypg_test。 CREATE TABLE ypg_test (id int, name varchar(50)); 2.开启事务1&#xff0c;进行INSERT操作。 START TRANSACTI…

使用代理绕过网站的反爬机制

最近在尝试收集一些网络指标的数据&#xff0c; 所以&#xff0c; 我又开始做爬虫了。 :) 我们在做爬虫的过程中经常会遇到这样的情况&#xff0c;最初爬虫正常运行&#xff0c;正常抓取数据&#xff0c;一切看起来都是那么的美好&#xff0c;然而一杯茶的功夫可能就会出现错误…

为什么单片机控制电机需要加电机驱动

通常很多地方只是单纯的单片机MCU没有对电机的驱动能力&#xff0c;或者是介绍关于电机驱动的作用&#xff0c;如&#xff1a; 提高电机的效率和精度。驱动器采用先进的电子技术和控制算法&#xff0c;能够精准控制电机的参数和运行状态&#xff0c;提高了电机的效率和精度。拓…

镜舟科技荣获金科创新社 2024 年度金融数据智能解决方案奖

近日&#xff0c; 镜舟科技凭借领先的金融实时数仓构建智能经营解决方案&#xff0c;在“金科创新社第六届金融数据智能优秀解决方案评选”活动中&#xff0c;成功入选“数据治理与数据平台创新优秀解决方案”榜单。 金科创新社主办的“鑫智奖”评选活动&#xff0c;旨在展示…

社交巨头与去中心化:解析Facebook在区块链的角色

在数字化时代&#xff0c;社交媒体已经成为人们日常生活中不可或缺的一部分。作为全球最大的社交媒体平台&#xff0c;Facebook 在社交领域的影响力无可置疑。然而&#xff0c;随着区块链技术的崛起&#xff0c;Facebook 也开始探索如何将这一技术应用于其平台&#xff0c;以适…

yolov5 的几个问题,讲的比较清楚

yolov5, 几个问题 【BCELoss】pytorch中的BCELoss理解 三个损失函数原理讲解 https://zhuanlan.zhihu.com/p/458597638 yolov5源码解析–输出 YOLOv5系列(十) 解析损失部分loss(详尽) 1、输入数据是 xywh, 针对原图的, 然后,变成 0-1, x/原图w, y/原图h, w/原图w, h/原图h,…

C++11 数据结构7 队列的链式存储,实现,测试

前期考虑 队列是两边都有开口&#xff0c;那么在链式情况下&#xff0c;线性表的链式那一边作为对头好呢&#xff1f; 从线性表的核心的插入和删除算法来看&#xff0c;如果在线性表链表的头部插入&#xff0c;每次循环都不会走&#xff0c;但是删除的时候&#xff0c;要删除线…

通过python实现分析出生日期辨识你的星座 出生日期判断星座

目录 一.总体说明 二.完整代码 三.逐行分析 一.总体说明 这段代码的主要功能是根据用户输入的出生日期,判断并输出对应的星座。 首先,定义了一个名为sdate的列表,其中包含了每个星座所对应的日期。接下来,定义了conts列表,存储了星座的名称,以及signs列表,存储了星座…