MyBatis-Plus:saveOrUpdate根据指定字段更新或插入方式

 更新时间:2025年04月01日 10:03:19   作者:五月天的尾巴  
这篇文章主要介绍了MyBatis-Plus:saveOrUpdate根据指定字段更新或插入方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

一、概述

MyBatis-Plus中提供了一个saveOrUpdate()方法,默认情况下可以根据主键是否存在进行更新或插入操作,但是实际场景中,我们会遇到根据指定字段进行更新或插入的情况。

以下记录一下如何根据指定字段进行更新或插入操作。

二、实现方式

  • 功能描述: 根据实体对象的主键 ID 进行判断,存在则更新记录,否则插入记录。
  • 返回值: boolean,表示插入或更新操作是否成功。
// @TableId 注解属性值存在则更新记录,否插入一条记录
boolean saveOrUpdate(T entity);

// 根据updateWrapper尝试更新,否继续执行saveOrUpdate(T)方法
boolean saveOrUpdate(T entity, Wrapper<T> updateWrapper);

若要根据指定字段更新,则使用saveOrUpdate(T entity, Wrapper<T> updateWrapper)方法。

IService中存在一种这样的方法,接收两个参数,

default boolean saveOrUpdate(T entity, Wrapper<T> updateWrapper) {
   return this.update(entity, updateWrapper) || this.saveOrUpdate(entity);
}

在执行时的执行逻辑是这样的:

  1. 首先根据updateWrapper查询需要更新哪个记录;
  2. 如果能查询到记录,则进行更新操作,更新时会根据entity对象属性的值进行更新,注意null值会忽略,如果未能查询到记录,则会把entity对象进行插入操作;

以一段代码给出详细的解释:

// 导入必要的类
import com.baomidou.mybatisplus.core.conditions.query.UpdateWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;

// 创建一个UpdateWrapper对象,指定查询条件
UpdateWrapper<User> updateWrapper = Wrappers.query();
updateWrapper.eq("id", 111);  // 假设这里是你的指定字段和条件

// 调用saveOrUpdate方法,传入实体对象和UpdateWrapper对象
userMapper.saveOrUpdate(user, updateWrapper);

三、总结

总的来说,saveOrUpdate(T entity, Wrapper updateWrapper)方法

会根据指定的条件先进行查询,然后根据查询结果自动决定是执行更新操作还是插入操作,从而实现根据指定字段执行保存或更新的逻辑。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • java金额数字转中文工具类详解

    java金额数字转中文工具类详解

    这篇文章主要为大家详细介绍了java金额数字转中文工具类的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-04-04
  • Sharding-jdbc报错:Missing the data source name:‘m0‘解决方案

    Sharding-jdbc报错:Missing the data source 

    在使用MyBatis-plus进行数据操作时,新增Order实体属性后,出现了数据源缺失的提示错误,原因是因为userId属性值使用了随机函数生成的Long值,这与sharding-jdbc的路由规则计算不匹配,导致无法找到正确的数据源,通过调整userId生成逻辑
    2024-11-11
  • 初始JAVA模块化开发的超详细步骤(适合菜鸟)

    初始JAVA模块化开发的超详细步骤(适合菜鸟)

    这篇文章主要介绍了初始JAVA模块化开发的超详细步骤,详细解释了模块描述符的职责、模块路径的概念以及如何使用命令行运行模块化Java程序,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2025-03-03
  • java实现角色及菜单权限的项目实践

    java实现角色及菜单权限的项目实践

    在Java中,实现角色及菜单权限管理涉及定义实体类、设计数据库表、实现服务层和控制器层,这种管理方式有助于有效控制用户权限,适用于企业级应用,感兴趣的可以一起来了解一下
    2024-09-09
  • 深入了解Java并发AQS的独占锁模式

    深入了解Java并发AQS的独占锁模式

    AQS是一种提供了原子式管理同步状态、阻塞和唤醒线程功能以及队列模型的简单框架。一般来说,同步工具实现锁的控制分为独占锁和共享锁,而AQS提供了对这两种模式的支持。本文主要来介绍一下独占锁模式,需要的可以参考一下
    2022-10-10
  • SpringBoot 整合 Avro 与 Kafka的详细过程

    SpringBoot 整合 Avro 与 Kafka的详细过程

    本文介绍了如何在Spring Boot中使用Avro和Kafka进行数据的序列化和反序列化,并通过MyBatisPlus将数据存入数据库,感兴趣的朋友跟随小编一起看看吧
    2024-12-12
  • java读取resource目录下文件的方法示例

    java读取resource目录下文件的方法示例

    这篇文章主要介绍了利用java读取resource目录下文件的方法,文中给出了详细的示例代码,相信对大家具有一定的参考借鉴,需要的朋友们下面来一起看看吧。
    2017-02-02
  • SpringBoot @Cacheable自定义KeyGenerator方式

    SpringBoot @Cacheable自定义KeyGenerator方式

    这篇文章主要介绍了SpringBoot @Cacheable自定义KeyGenerator方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-12-12
  • Java使用modbus4j实现modbus tcp通讯

    Java使用modbus4j实现modbus tcp通讯

    Modbus是由Modicon(现为施耐德电气公司的一个品牌)在1979年发明的,是全球第一个真正用于工业现场的总线协议,本文主要介绍了java如何使用modbus4j实现modbus tcp通讯,感兴趣的可以了解下
    2023-12-12
  • Java 项目连接并使用 SFTP 服务的示例详解

    Java 项目连接并使用 SFTP 服务的示例详解

    SFTP是一种安全的文件传输协议,是SSH(Secure Shell)协议的一个子协议,设计用于加密和保护文件传输的安全性,这篇文章主要介绍了Java 项目如何连接并使用 SFTP 服务的示例详解,需要的朋友可以参考下
    2025-01-01

最新评论