首页 > 其他分享 >Mybatis的saveOrUpdateBatch________批量保存或更新

Mybatis的saveOrUpdateBatch________批量保存或更新

时间:2023-09-03 14:34:37浏览次数:36  
标签:saveOrUpdateBatch ________ 批量 更新 插入 Mybatis 数据

一、saveOrUpdateBatch介绍

Mybatis是一种优秀的ORM框架,为了提高效率,Mybatis提供了批量执行操作的方法。saveOrUpdateBatch是其中一个方法,它可以保存或更新多组数据。

二、怎样使用saveOrUpdateBatch

要使用Mybatis的saveOrUpdateBatch方法,您需要先创建一个Mapper接口,并在其中定义一个对应的方法。这个方法需要接收一个List对象作为输入参数,表示需要保存或更新的数据。

首先声明一个Mapper接口,其中定义了方法saveOrUpdateBatch:

public interface UserMapper {
    void saveOrUpdateBatch(List userList);
}

注意:如果您使用的是Mybatis Plus,建议使用BaseMapper中已经封装好的saveOrUpdateBatch方法。

接下来看一个User实体类的例子:

public class User {
    private Long id;
    private String name;
    private Integer age;
    //getter和setter
}

然后在XML配置文件中配置方法的SQL语句:

<insert id="saveOrUpdateBatch" parameterType="java.util.List">
    insert into user(name, age)
    values
    <foreach collection="list" item="user" separator=",">
        (#{user.name}, #{user.age})
    </foreach>
    on duplicate key 
    update name=values(name), age=values(age);
</insert>

请注意:这个SQL语句在MySQL上通过,如果您使用其他数据库,请修改SQL语法。

最后,在Java代码中调用Mapper的saveOrUpdateBatch方法即可实现批量保存或更新。例如:

@Autowired
UserMapper userMapper;

User user1 = new User("Lucy", 18);
User user2 = new User("Tom", 20);
List<User> userList = Arrays.asList(user1, user2);

userMapper.saveOrUpdateBatch(userList);

三、saveOrUpdateBatch的实现原理

saveOrUpdateBatch实际上是Mybatis的批量插入(batch)和批量更新的结合体。当我们执行saveOrUpdateBatch时,Mybatis会执行一个insert语句,将数据批量插入到数据库中。如果插入时有冲突(如主键重复),则会执行一个update语句,对已存在的数据进行更新。

具体来说,Mybatis会将用户传入的List数据按顺序拆分成两部分:需要插入的数据和需要更新的数据。然后它会将需要插入的数据拆分成多组数据,并执行批量插入操作。如果在插入时有冲突,Mybatis会记录下出现冲突的数据。

接下来,Mybatis会将需要更新的数据与冲突的数据合并成一组数据,并执行批量更新操作。

总的来说,saveOrUpdateBatch方法相当于执行了一个批量插入操作和一个批量更新操作。

四、saveOrUpdateBatch方法的应用场景

1. 提高效率

相比于一次次地执行insert和update操作,使用saveOrUpdateBatch可以大幅提高代码的效率,减少数据库访问的次数。

2. 减少代码量

如果需要保存或更新数百条以上的数据,使用单个insert或update语句不仅效率低下,代码量也会非常庞大。而使用saveOrUpdateBatch方法,我们只需要写一个Mapper方法和一个SQL语句即可。

3. 处理数据冲突

当我们需要保存一批数据时,有时会出现数据冲突的情况,如主键重复。使用saveOrUpdateBatch可以方便地对这些冲突数据进行更新,而不需要手动编写冲突处理的代码。

五、小结

saveOrUpdateBatch是Mybatis提供的一种批量保存或更新的方法,可以大幅提高插入和更新数据的效率,减少代码量。它会执行一个批量插入和一个批量更新操作,可以方便地处理数据冲突。

 

==============================================================================================================================================

问题:数据量大IO缓慢

 

    最近mybatis-plus框架的更新,让我们基础开发中如虎添翼。其中基本的增删改查,代码生成器想必大家用着那叫一个爽。本人在使用中,也遇到一些坑。比如savebatch,saveorupdatebatch,看着这不是批量新增,批量新增或更新嘛,看着api进行开发,感觉也太好用啦。开发完一测试,速度跟蜗牛一样,针对大数据量真是无法忍受。在控制台上发现,怎么名义上是批量插入,还是一条一条的进行插入,难怪速度龟速。

二.解决办法

    查阅网上资料,大体有两种解决方案:

    (1).使用mybatis的xml,自己进行sql语句编写。该方法一个缺点是如果表的字段较多,有个几十个字段,写批量新增,批量新增修改的sql语句真是个噩梦。

 

  (2)mybatis-plus 新添加了一个sql注入器,通过sql注入器可以实现批量新增,批量新增修改功能。一次注入,随时使用,使用极其方便。缺点就是项目启动时候,会进行sql注入器注册,稍微影响启动速度。

 

问题解决原文链接: https://blog.csdn.net/qq_28025423/article/details/115680196

标签:saveOrUpdateBatch,________,批量,更新,插入,Mybatis,数据
From: https://www.cnblogs.com/jiaodaoniujava/p/17674940.html

相关文章

  • C#数据结构之Tree
    usingSystem;usingSystem.Collections.Generic;usingSystem.Linq;usingSystem.Text;usingSystem.Threading.Tasks;namespaceAlgorithmsDemo{publicclassTreeNode<T>{publicTData{get;set;}publicList<TreeNode<......
  • 自我介绍+软工5问
    自我介绍+软工5问作业概述这个作业属于哪个课程软件工程这个作业要求在哪里自我介绍+软工五问这个作业的目标熟悉平台,初步认识软件工程自我介绍我是黄梦莎,目前是广东工业大学计算机科学与技术的大三学生,来自广东潮州,ENTJ。我从小在广东和辽宁长大,喜欢跑步,喜......
  • vue3入门_demo
    新建项目参考:Vuevscode创建vue项目流程【超详细】_vuevscode创建vue项目流程【超详细】_怎么用vscode写vue_一颗不甘坠落的流_一颗不甘坠落的流星的博客-CSDN博客项目结构:App.vue<template><Main></Main></template><script>importMainfrom"./components......
  • Apollo分布式配置中心
    ......
  • zookeeper
    ......
  • AI绘画:StableDiffusion实操教程-斗罗大陆2-江楠楠-常服(附高清图下载)
    前段时间我分享了StableDiffusion的非常完整的教程:“AI绘画:StableDiffusion终极宝典:从入门到精通”尽管如此,还有读者反馈说,尽管已经成功安装,但生成的图片与我展示的结果相去甚远。真实感和质感之间的差距到底在哪里?关键之处在于使用正确的大模型model和专用的lora包。今天,我......
  • Jenkins安装
    持续部署持续集成持续交付总体目标1.降低风险2.减少重复过程3.任何时间、任何地点使乘客部署的软件4.增强项目的可见性5.建立团队对开发产品的信心持续集成工具1.Jenkins和Hudson在ubuntu下安装jenkinswget-q-O-https://pkg.jenkins.io/debian/jenkins-ci.org......
  • Docker构建Jenkins
    拉取jenkins的docker镜像,这里用的是lts的长期支持版本,你可以到jenkins官网自由选择其他版本(下载速度慢,花了两个小时,如果中途出现超时再次运行该命令即可)dockerpulljenkins/jenkins:lts配置宿主机映射到容器的目录,之后jenkins的一些配置文件......
  • 无涯教程-JavaScript - QUARTILE函数
    QUARTILE函数取代了Excel2010中的QUARTILE.INC函数。描述该函数返回数据集的四分位数。四分位数通常用于销售和调查数据中,以将人群分为几类。语法QUARTILE(array,quart)争论Argument描述Required/OptionalArrayThearrayorcellrangeofnumericvaluesforwhi......
  • 这才是BGP的聚合!!!
    BGP聚合:作用:减少肯干路由器路由条目;提高肯干稳定减少震荡分类:第三项选路:手动>自动>自己network>自2import>从其他邻居学习到的1.自动聚合:summaryautomatic公认任意只能聚合本台设备引入的,对自己network和其他设备引入的路由无效聚合后会产生一条、有类的聚合后的路由聚......