MyBatis-Plus updateById不更新null值的方法解决

 更新时间:2023年08月25日 11:41:31   作者:一碗情深  
用Mybatis-Plus的updateById()来更新数据时,无法将字段设置为null值,更新后数据还是原来的值,本文就来详细的介绍一下解决方法,具有一定的参考价值,感兴趣的可以了解一下

前言

在 MyBatis-Plus 中,使用updateById,null字段并不会更新,其实是和更新的策略有关,当然,也有插入策略,本文基于MyBatis-Plus3.5.2,对插入和更新策略做讲解。

方式一 调整全局的验证策略

注入全局配置,设置属性 insertStrategyupdateStrategy

缺点:这样做会对所有的字段都忽略判断,如果一些字段不想要修改,但是传值的时候没有传递过来,就会被更新为null

mybatis-plus:
  global-config:
    db-config:
      insert-strategy: ignored  # "忽略判断", 所有字段都插入
      update-strategy: ignored  # "忽略判断", 所有字段都更新

insertStrategyupdateStrategy 属性的值有以下5种枚举类型:

  • ignored “忽略判断”, 所有字段都更新或插入
  • not_null “非 NULL 判断”, 只更新或插入非NULL值
  • not_empty “非空判断”, 只更新或插入非NULL值且非空字符串
  • default 如果字段的值不为null,则进行插入或者更新操作;如果字段的值为null,不执行操作,执行结果还是数据库原来的值或者默认值
  • never 永远不进行插入或更新操作,即使字段的值不为null

方式二 调整字段验证注解

在属性上注解

根据具体情况,在需要更新或者插入的字段中调整验证注解,如忽略判断,任何情况都进行插入和更新操作:

@TableField(updateStrategy = FieldStrategy.IGNORED, insertStrategy = FieldStrategy.IGNORED)

方式三 使用 UpdateWrapper

如果没有设置 insert-strategyupdate-strategy 的值,默认为 default

使用以下方法来进行更新操作,无设置的值还是数据库原来的值,如下

UpdateWrapper<User> updateWrapper = new UpdateWrapper<>();
updateWrapper.set("name", "一碗情深")
    .set("url", "https://blog.csdn.net/xiaohuihui1400")
    .eq("id", 1);
userMapper.update(null, updateWrapper);

或者使用lambda表达式,只有将属性赋值,数据库的值才会改变,如下,把email设置成null

mapper.update(
    null,
    Wrappers.<User>lambdaUpdate()
        .set(User::getName, "一碗情深")
		.set(User::getUrl, "https://blog.csdn.net/xiaohuihui1400")
        .set(User::getEmail, null) // 把email设置成null
        .eq(User::getId, 1)
);

 到此这篇关于MyBatis-Plus updateById不更新null值的方法解决的文章就介绍到这了,更多相关MyBatis-Plus updateById不更新null值内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java网络编程教程之设置请求超时的方法

    Java网络编程教程之设置请求超时的方法

    这篇文章主要给大家介绍了关于Java网络编程教程之设置请求超时的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2017-12-12
  • Java如何导出多个excel并打包压缩成.zip文件

    Java如何导出多个excel并打包压缩成.zip文件

    本文介绍了Java如何导出多个excel文件并将这些文件打包压缩成zip格式,首先,需要从数据库中获取数据并导出到指定位置形成excel文件,接着,将这些数据分散到不同的excel文件中,最后,使用相关的Java工具类对这些excel文件进行打包压缩
    2024-09-09
  • Spring Boot中集成各种日志框架Logback、Log4j2和Java Util Logging的步骤和示例代码

    Spring Boot中集成各种日志框架Logback、Log4j2和Java Util 

    这篇文章主要介绍了Spring Boot中集成各种日志框架Logback、Log4j2和Java Util Logging,通过实例代码介绍了集成Logback、Log4j2和Java Util Logging的基本步骤,你可以根据自己的需求进行配置和扩展,以满足更复杂的日志需求,需要的朋友可以参考下
    2023-11-11
  • Springboot实现文件上传至linux指定目录

    Springboot实现文件上传至linux指定目录

    这篇文章主要为大家详细介绍了springboot项目如何实现一个文件上传接口,涉及vsftpd服务、SSH协议以及对linux系统的一些配置,希望对大家有所帮助
    2025-08-08
  • java制作专属智能陪聊机器人详解

    java制作专属智能陪聊机器人详解

    人工智能一直是最近的热点话题,,这篇文章主要为大家详细介绍了java实现智能陪聊机器人,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-11-11
  • 基于java实现颜色拾色器并打包成exe

    基于java实现颜色拾色器并打包成exe

    这篇文章主要为大家详细介绍了如何基于java编写一个简单的颜色拾色器并打包成exe文件,文中的示例代码讲解详细,需要的小伙伴可以跟随小编一起学习一下
    2023-10-10
  • java 交换两个数据的方法实例详解

    java 交换两个数据的方法实例详解

    这篇文章主要介绍了java 交换两个数据的方法实例详解的相关资料,需要的朋友可以参考下
    2016-12-12
  • Java使用itext生成pdf标签的操作方法

    Java使用itext生成pdf标签的操作方法

    iText是著名的开放源码的站点sourceforge一个项目,是用于生成PDF文档的一个java类库,通过iText不仅可以生成PDF或rtf的文档,而且可以将XML、Html文件转化为PDF文件,本文给大家介绍了Java使用itext生成pdf标签的操作方法,需要的朋友可以参考下
    2024-12-12
  • SpringBoot如何实现word文档转pdf

    SpringBoot如何实现word文档转pdf

    这篇文章主要介绍了SpringBoot如何实现word文档转pdf,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • SpringBoot使用@ControllerAdvice进行统一处理异常详解

    SpringBoot使用@ControllerAdvice进行统一处理异常详解

    在实际开发中,程序运行时难免会遇到各种意外,如果不做统一处理,用户可能会看到一堆错误信息,下面我们就来看看SpringBoot如何使用@ControllerAdvice进行统一处理异常吧
    2026-01-01

最新评论