mybatisplus如何根据不同ID批量更新
多个id修改相同属性值——使用Wrapper
在MyBatis-Plus里,想给一批ID对应的记录,统一修改某个字段的值,UpdateWrapper是个非常趁手的工具。它能让你的批量更新操作变得既清晰又高效。
免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

具体怎么用呢?来看一个典型的场景:假设你需要把ID为1、2、3的用户年龄都改为20岁。代码可以这样写:
ListidList = 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:
ListidList = 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方法,传入这个列表。 - 最后,根据方法的返回值(布尔类型)来判断批量操作是否成功。
来看一个具体的代码示例:
ListuserList = 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根据条件只更新一个字段的实现
热门专题
热门推荐
TripMate是什么 规划一次完美的旅行,最磨人的往往是前期的信息海选和行程拼图。现在,一款名为TripMate的AI旅行助手,正试图把我们从这种繁琐中解放出来。简单来说,它是一个由人工智能驱动的个人旅行规划工具,核心目标就一个:让个性化的行程规划变得又快又省心。用户不必再在各种攻略网站间反复横跳
Artwo是什么 浏览器标签页多到能开火车,收藏夹杂乱得像毛线球——这大概是每个深度上网冲浪者的日常痛点。Artwo的出现,正是为了终结这种混乱。这款工具的核心,是将AI的智能与网页资源管理深度结合,帮你把散落各处的网页信息,整理成井井有条的知识库。它不仅仅是个高级书签管理器,更像是一个能理解你需求
Best AI Jobs是什么 当你琢磨着在人工智能领域找份新工作时,面对海量却不精准的招聘信息,是不是常常感到头疼?这时候,一个专业的垂直平台就显得尤为重要了。Best AI Jobs,正是为此而生。它是一个专注于人工智能领域的职业搜索引擎,核心使命就是帮用户在全球范围内精准定位AI相关的职位。无
FreeAIKit是什么 当你听到“AI工具套件”时,脑子里会浮现什么?复杂的代码、难懂的术语,还是昂贵的订阅费?FreeAIKit的出现,可以说彻底打破了这些刻板印象。这个由Easy With AI打造的综合平台,目标非常明确:让AI变得触手可及。它集成了图像生成、市场营销、生产力提升等一系列工具
WPS Office是什么 提到办公软件,很多人的第一反应可能是微软的Office套件。但今天,我们得好好聊聊另一个重量级选手——WPS Office。它出自中国的金山软件,是一款功能完整的免费办公解决方案。简单来说,它集成了文档编辑、表格处理、幻灯片制作以及PDF工具于一体,旨在为用户提供一个流畅





