当前位置: 首页
编程语言
mybatisplus如何根据不同ID批量更新

mybatisplus如何根据不同ID批量更新

热心网友 时间:2026-04-23
转载

多个id修改相同属性值——使用Wrapper

在MyBatis-Plus里,想给一批ID对应的记录,统一修改某个字段的值,UpdateWrapper是个非常趁手的工具。它能让你的批量更新操作变得既清晰又高效。

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

mybatisplus如何根据不同ID批量更新

具体怎么用呢?来看一个典型的场景:假设你需要把ID为1、2、3的用户年龄都改为20岁。代码可以这样写:

List idList = Arrays.asList(1, 2, 3);
User user = new User();
user.setAge(20);

UpdateWrapper wrapper = new UpdateWrapper<>();
wrapper.in("id", idList);
int rows = userMapper.update(user, wrapper);

这段代码的逻辑很直观:先准备好目标ID列表和要设置的新值,然后用UpdateWrapper构建一个条件——in(“id”, idList),意思就是“找出所有ID在列表里的记录”。最后,调用update方法,框架就会精准地更新这些符合条件的记录了,返回的rows就是实际被修改的行数。

这里有个细节值得注意:UpdateWrapper配合实体对象更新时,默认会忽略实体对象中为null的字段。也就是说,如果你只想更新部分字段,把其他字段留空就行。但如果你的业务需求恰恰是要把某个字段更新为null,那就得换种写法,使用wrapper.setSql(“column_name = null”)来显式指定。

多个id修改相同属性值——不使用Wrapper

相关问题

当然,不是所有场景都非得用Wrapper。比如,你手头有一个ID数组,想批量更新这些记录的同个属性,MyBatis-Plus的Service层还提供了一个更直接的方法:updateBatchById

这个方法用起来更简洁。看下面的例子,目标是把ID为1、2、3的用户的年龄都设为18:

List idList = Arrays.asList(1, 2, 3);
User user = new User();
user.setAge(18);
int rows = userService.updateBatchById(idList, user);

代码一目了然:传入ID集合和承载新值的实体对象,方法内部会帮你完成批量更新,并返回影响的行数。这种写法非常适合快速实现“按ID列表批量设值”的需求。

不过,简洁的背后也需要一点考量:这个方法会更新列表中所有ID对应的整条记录。因此,当数据量非常大时,需要评估一下对数据库性能的潜在影响。对于海量数据的更新,或许分批次处理会是更稳妥的选择。

多个id修改多个属性值——不同id的不同属性

前面说的都是“一刀切”的更新,那如果情况更复杂呢?比如,不同ID的记录需要更新成不同的值。这种“个性化批量更新”的需求,同样有解。

MyBatis-Plus提供的updateBatchById方法还有一个重载版本,它接收一个实体对象列表。列表里的每个实体对象,都必须包含主键ID和需要更新的字段值。框架会根据ID,精准地更新每条记录对应的字段。

实现步骤分三步走:

  • 首先,构建一个实体对象列表,每个对象代表一条待更新的记录,并设置好其ID和新值。
  • 然后,调用Service层的updateBatchById方法,传入这个列表。
  • 最后,根据方法的返回值(布尔类型)来判断批量操作是否成功。

来看一个具体的代码示例:

List userList = new ArrayList<>();
User user1 = new User();
user1.setId(1L);
user1.setName("Tom");
userList.add(user1);

User user2 = new User();
user2.setId(2L);
user2.setName("Jerry");
userList.add(user2);

// 调用 updateBatchById 方法批量修改记录
boolean success = userService.updateBatchById(userList);

if (success) {
  System.out.println("批量修改成功!");
} else {
  System.out.println("批量修改失败!");
}

这段代码模拟了一个常见操作:将ID为1的用户名改为“Tom”,同时将ID为2的用户名改为“Jerry”。

这里有一个至关重要的前提:你的实体类(示例中的User)必须继承MyBatis-Plus的Model类。只有这样,框架才能正确识别出哪个字段是主键(ID),从而执行基于ID的批量更新。如果没继承,这个方法可就“认不出”你的数据了。

总结

总的来说,MyBatis-Plus为批量更新提供了灵活多样的选择。无论是使用UpdateWrapper进行条件批量更新,还是直接使用updateBatchById根据ID列表或实体列表进行更新,核心都是选择最适合当前业务场景的工具。掌握这几种方式,面对不同的批量数据处理需求时,你就能更加得心应手了。

您可能感兴趣的文章:

  • MyBatisPlus通过ID更新数据为NULL的四种方法
  • ja va mybatisplus批量新增和更新方式
  • MybatisPlus插件自动维护更新和创建时间方式
  • Mybatisplus更新某个字段为null问题
  • mybatisplus根据条件只更新一个字段的实现
来源:https://www.jb51.net/program/362689ubl.htm

游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

同类文章
更多
SpringBoot+Vue3实现登录验证码功能教程

SpringBoot+Vue3实现登录验证码功能教程

前言 登录页面,输入用户名和密码进行验证,这对各位开发者来说早已是家常便饭。但说到那个需要用户手动填写、甚至时不时需要“看不清?换一张”的图片验证码,不少朋友在实现时可能会犯嘀咕:这随机生成的图片,到底该怎么弄? 今天,我们就来重点拆解这个功能:如何在后端生成验证码图片,如何在前端展示并实现点击刷新

时间:2026-04-25 16:31
Java实现抠图的三种主流方案详解

Java实现抠图的三种主流方案详解

Ja va实现抠图的三种主流方案详解 在Ja va项目里实现图片抠图,也就是把背景去掉或者把主体单独拎出来,这事儿说简单也简单,说复杂也复杂。关键看你要处理的是什么类型的图片。是绿幕视频截图,还是普通的生活照,或者对头发丝这种细节要求极高?不同的场景,技术路径的选择天差地别。 总的来说,目前主流的实

时间:2026-04-25 16:31
HDFS与YARN如何协同配置

HDFS与YARN如何协同配置

HDFS与YARN协同配置:让数据存储与资源管理无缝对接 在Hadoop生态里,HDFS和YARN堪称黄金搭档,一个管数据存储,一个管资源调度。想让它们默契配合,高效运转,关键就在于正确的协同配置。下面这份配置指南,可以说是搭建稳定Hadoop集群的必经之路。 1 配置HDFS:打好数据地基 HD

时间:2026-04-25 16:30
如何调整HDFS的内存设置

如何调整HDFS的内存设置

要调整HDFS(Hadoop分布式文件系统)的内存设置,您需要修改Hadoop配置文件中的相关参数。以下是一些关键参数及其调整方法: 1 调整NameNode内存设置 作为HDFS的“大脑”,NameNode负责管理整个文件系统的元数据。它的内存配置直接关系到集群的响应能力和稳定性。调整其内存设置

时间:2026-04-25 16:30
如何通过dmesg诊断硬件故障

如何通过dmesg诊断硬件故障

如何通过dmesg诊断硬件故障 在Linux系统管理和故障排查的“工具箱”里,dmesg(display message或driver message)绝对算得上是一把“瑞士军刀”。这个看似简单的命令行工具,能直接读取内核环形缓冲区中的消息,为我们揭示系统启动的完整历程和运行时的内部状态。当硬件出现

时间:2026-04-25 16:30
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程