41. 如何在MyBatis-Plus中实现批量操作?批量插入和更新的最佳实践是什么?

ops/2024/9/25 14:56:32/

在 MyBatis-Plus 中,实现批量操作(如批量插入、批量更新)是非常常见的需求。MyBatis-Plus 提供了对批量操作的良好支持,可以通过多种方式实现高效的批量处理。下面详细介绍批量操作的实现方式以及最佳实践。

1. 批量插入

批量插入是指一次性插入多条记录,而不是逐条插入。MyBatis-Plus 提供了多种方式来实现批量插入。

1.1 使用 insertBatchSomeColumn 方法

MyBatis-Plus 提供了 insertBatchSomeColumn 方法,可以直接插入一个集合的所有元素。这个方法通常用于插入时可以选择性地忽略一些不需要的字段(如主键自增的场景)。

示例:

java">import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import org.springframework.stereotype.Service;
​
@Service
public class UserService extends ServiceImpl<UserMapper, User> {
​public boolean batchInsert(List<User> userList) {return this.saveBatch(userList);}
}

调用示例:

java">List<User> userList = new ArrayList<>();
userList.add(new User("Alice", 25));
userList.add(new User("Bob", 30));
​
userService.batchInsert(userList);
  • saveBatch:MyBatis-Plus 提供的 saveBatch 方法可以一次性插入多个记录。该方法默认使用了批量插入的 SQL 优化,可以在一定程度上减少数据库的连接开销。

1.2 使用 Mapper 接口的批量插入

你也可以通过在 Mapper 接口中自定义批量插入的 SQL 语句来实现批量插入操作。

自定义批量插入 SQL:

java">import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Param;
import java.util.List;
​
public interface UserMapper extends BaseMapper<User> {
​@Insert("<script>" +"INSERT INTO user (name, age) VALUES " +"<foreach collection='list' item='user' separator=','>" +"(#{user.name}, #{user.age})" +"</foreach>" +"</script>")int batchInsert(@Param("list") List<User> userList);
}

调用示例:

java">List<User> userList = new ArrayList<>();
userList.add(new User("Alice", 25));
userList.add(new User("Bob", 30));
​
userMapper.batchInsert(userList);
  • <foreach> 标签:在 MyBatis 的 XML 中使用 <foreach> 标签遍历集合,并生成批量插入的 SQL 语句。

2. 批量更新

批量更新指的是一次性更新多条记录。与批量插入类似,MyBatis-Plus 也提供了多种方式实现批量更新。

2.1 使用 updateBatchById 方法

MyBatis-Plus 提供了 updateBatchById 方法,支持根据 ID 批量更新多个实体。

示例:

java">@Service
public class UserService extends ServiceImpl<UserMapper, User> {
​public boolean batchUpdate(List<User> userList) {return this.updateBatchById(userList);}
}

调用示例:

java">List<User> userList = new ArrayList<>();
userList.add(new User(1L, "Alice", 26)); // 更新ID为1的用户
userList.add(new User(2L, "Bob", 31)); // 更新ID为2的用户
​
userService.batchUpdate(userList);
  • updateBatchById:该方法会根据传入的实体集合中的 ID,依次更新对应的记录。每个实体只更新有变动的字段。

2.2 自定义批量更新 SQL

你也可以通过在 Mapper 接口中自定义批量更新的 SQL 语句来实现批量更新操作。

自定义批量更新 SQL:

java">import org.apache.ibatis.annotations.Update;
import org.apache.ibatis.annotations.Param;
import java.util.List;
​
public interface UserMapper extends BaseMapper<User> {
​@Update("<script>" +"<foreach collection='list' item='user' separator=';'>" +"UPDATE user " +"SET name = #{user.name}, age = #{user.age} " +"WHERE id = #{user.id}" +"</foreach>" +"</script>")int batchUpdate(@Param("list") List<User> userList);
}

调用示例:

java">List<User> userList = new ArrayList<>();
userList.add(new User(1L, "Alice", 26));
userList.add(new User(2L, "Bob", 31));
​
userMapper.batchUpdate(userList);
  • <foreach> 标签:与批量插入类似,使用 <foreach> 标签遍历集合并生成批量更新的 SQL 语句。

3. 批量操作的最佳实践

  1. 使用批量操作方法:MyBatis-Plus 提供的 saveBatchupdateBatchById 方法已经优化了 SQL 执行的效率,建议优先使用这些方法。

  2. 控制批量操作的大小:在批量插入或更新时,最好控制单次操作的批量大小(例如每次操作 1000 条记录),以避免 SQL 语句过长或数据库连接超时问题。

  3. 考虑使用数据库事务:批量操作通常需要涉及多条 SQL 语句的执行,为了保证操作的原子性,可以考虑在批量操作时使用数据库事务。

  4. 使用乐观锁:如果批量更新操作涉及并发写入,建议使用乐观锁来避免数据冲突,MyBatis-Plus 支持通过 @Version 注解实现乐观锁机制。

  5. 合理配置 MyBatis-Plus 插件:在高并发场景下,合理配置 MyBatis-Plus 的分页、乐观锁、SQL 性能分析等插件,可以提高应用的性能和稳定性。

总结

  • 批量插入:可以通过 MyBatis-Plus 的 saveBatch 方法实现,或者通过自定义 Mapper 接口的批量插入 SQL 语句实现。

  • 批量更新:可以通过 MyBatis-Plus 的 updateBatchById 方法实现,或者通过自定义 Mapper 接口的批量更新 SQL 语句实现。

  • 最佳实践:在批量操作中,合理控制批量大小、使用事务、应用乐观锁,以及配置好插件,可以确保批量操作的高效和稳定。

MyBatis-Plus 为批量操作提供了简便的接口和优化手段,使得开发者可以更加高效地处理大批量数据的插入和更新操作。


http://www.ppmy.cn/ops/115830.html

相关文章

fo-dicom,第一个基于.NET Standard 2.0 开发的DICOM开源库

1. 简介&#xff1a; fo-dicom是一个基于C#开发的库&#xff0c;用于处理DICOM&#xff08;Digital Imaging and Communications in Medicine&#xff09;格式的数据。DICOM是一种用于医学影像和相关信息的标准格式&#xff0c;广泛应用于医学领域。fo-dicom提供了多平台支持&…

日常生活中喝够水,能帮助预防多种慢性病、提高免疫力,还能改善情绪、提高认知能力!

文章目录 引言多喝水的好处为何人体中水分含量这么高?引言 感到口渴时,人体缺水程度已经在 1%~2% 了。建议大家养成随时喝、少量多次的习惯,在口渴前喝水,避免影响健康。 水分的丢失却无时无刻不在发生,即便没有大量出汗,每天通过呼吸、排泄、皮肤蒸发就能排出 1.5~2 升…

Oracle和JSON结合起来,开发者的福利

Oracle Database 23c在简化开发、应对开发发力了&#xff0c;更多拥抱开发者方面的能力&#xff0c;真的是人惊讶&#xff0c;这几天也是参加Oracle官方组织的AI专家培训&#xff0c;受益非浅&#xff0c;在这里给大家分享一下通过 ORDS操作对外暴露Http Restful服务&#xff0…

【多模态大模型】Qwen2-VL基本原理和推理部署实战

文章目录 Qwen2-VL基本原理Qwen-VL简要回顾Qwen2-VL的高级升级统一视觉处理方式原生动态分辨率处理&#xff08;非大图切分方式&#xff09;多模态旋转位置编码 Qwen2-VL推理实现|代码解析单图推理视觉信息预处理找到能被28整除的最合适size最大最小pixel数边界处理 多模态信息…

mysql怎么让字段从1开始自增?

mysql怎么让字段从1开始自增&#xff1f; 要确保一个 AUTO_INCREMENT 字段从1开始自增&#xff0c;你需要在创建表的时候指定 AUTO_INCREMENT 的起始值为1&#xff0c; 或者在表创建之后手动设置 AUTO_INCREMENT 的值。 1.创建表时指定 当你创建表的时候&#xff0c;可以直接…

新峰商城之分类三级联动实现

新峰商城是一个开源电子商务网站&#xff08;SpringBoot项目&#xff09;&#xff0c;本文主要简述它的商品分类中三级联动功能的实现。 一、多层级联动效果的常见场景 二、三级联动或者更多层级的数据联动是常见交互方式&#xff0c;它可以提升用户体验&#xff0c;限制用户随…

Qt上下文菜单

在Qt中&#xff0c;上下文菜单&#xff08;Context Menu&#xff09;是一种弹出式的、与用户当前鼠标位置相关的菜单&#xff0c;它通常用于提供针对特定元素的快速操作选项&#xff0c;比如右键点击某个控件时会出现的菜单。Qt::ContextMenuPolicy是一个枚举类型&#xff0c;用…

Python知识点:如何使用C/C++扩展Python功能

开篇&#xff0c;先说一个好消息&#xff0c;截止到2025年1月1日前&#xff0c;翻到文末找到我&#xff0c;赠送定制版的开题报告和任务书&#xff0c;先到先得&#xff01;过期不候&#xff01; 在Python中&#xff0c;你可以使用C或C来编写扩展模块&#xff0c;从而提高性能…