MyBatis-Plus更新字段为null的处理方案

 更新时间:2025年08月06日 10:45:51   作者:有来技术  
在使用 MyBatis-Plus 进行开发时,我们经常会遇到需要更新或插入字段为 null 的场景,然而,MyBatis-Plus 默认会忽略 null 值字段,导致这些字段不会被更新或插入到数据库中,本文将详细介绍如何解决 MyBatis-Plus 更新字段为 null 的问题,需要的朋友可以参考下

无废话

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

在使用 MyBatis-Plus 进行开发时,我们经常会遇到需要更新或插入字段为 null 的场景。然而,MyBatis-Plus 默认会忽略 null 值字段,导致这些字段不会被更新或插入到数据库中。本文将详细介绍如何通过配置 @TableField 注解的字段策略,解决 MyBatis-Plus 更新字段为 null 的问题。

问题背景

在 MyBatis-Plus 中,默认的字段策略是忽略 null 值字段。这意味着:

  • 在插入操作时,如果字段值为 null,则该字段不会被 插入到数据库中。
  • 在更新操作时,如果字段值为 null,则该字段不会被更新到数据库中。

这种默认行为在某些场景下可能会导致问题。例如,当我们希望将某个字段的值更新为 null 时,MyBatis-Plus 会忽略该操作,导致字段值未被正确更新。

解决方案

MyBatis-Plus 提供了 @TableField 注解,通过配置 insertStrategyupdateStrategy 属性,可以灵活控制字段的插入和更新策略。

1. 配置 @TableField 注解

通过在实体类的字段上添加 @TableField 注解,并设置 insertStrategyupdateStrategyFieldStrategy.IGNORED,可以强制 MyBatis-Plus 在插入和更新时处理 null 值字段。

@Data
@TableName("user")
public class User {
    private Long id;
    private String name;

    @TableField(
        insertStrategy = FieldStrategy.IGNORED,  // 插入时忽略字段是否为 null
        updateStrategy = FieldStrategy.IGNORED   // 更新时忽略字段是否为 null
    )
    private String email;  // 允许为 null
}

关键点解释:

  • insertStrategy = FieldStrategy.IGNORED
    • 在插入操作时,即使字段值为 null,也会将该字段插入到数据库中。
  • updateStrategy = FieldStrategy.IGNORED
    • 在更新操作时,即使字段值为 null,也会将该字段更新到数据库中。

2. 其他字段策略

MyBatis-Plus 提供了多种字段策略,可以根据实际需求选择:

  • FieldStrategy.DEFAULT:默认策略,跟随全局配置。
  • FieldStrategy.IGNORED:忽略字段是否为 null,始终插入或更新。
  • FieldStrategy.NOT_NULL:字段为非 null 时才插入或更新。
  • FieldStrategy.NOT_EMPTY:字段为非空(非 null 且非空字符串)时才插入或更新。
  • FieldStrategy.NEVER:始终不插入或更新该字段。

3. 全局配置

如果你希望全局配置字段策略,可以在 MyBatis-Plus 的全局配置中设置:

mybatis-plus:
  global-config:
    db-config:
      insert-strategy: ignored  # 全局插入策略
      update-strategy: ignored  # 全局更新策略

通过全局配置,可以避免在每个字段上单独设置 @TableField 注解,简化代码。

示例场景

假设有一个用户表 user,其中 email 字段允许为 null。我们希望:

  • 在插入操作时,即使 emailnull,也能插入到数据库中。
  • 在更新操作时,即使 emailnull,也能更新到数据库中。

实体类配置如下:

@Data
@TableName("user")
public class User {
    private Long id;
    private String name;

    @TableField(
        insertStrategy = FieldStrategy.IGNORED,
        updateStrategy = FieldStrategy.IGNORED
    )
    private String email;  // 允许为 null
}

注意事项

数据库约束

  • 如果数据库字段设置为 NOT NULL,即使配置了 IGNORED 策略,插入或更新 null 值时仍会抛出数据库异常。
  • 确保数据库字段允许 null 值。

性能影响

  • 使用 IGNORED 策略可能会导致不必要的字段更新(即使值未变化),需根据实际场景权衡。

总结

通过配置 @TableField 注解的 insertStrategyupdateStrategy 属性,我们可以灵活控制 MyBatis-Plus 对 null 值字段的处理行为。无论是全局配置还是字段级别的配置,都能有效解决更新字段为 null 的问题。在实际开发中,建议根据具体需求选择合适的字段策略,并注意数据库约束和性能影响。

以上就是MyBatis-Plus更新字段为null的处理方案的详细内容,更多关于MyBatis-Plus更新字段为null的资料请关注脚本之家其它相关文章!

相关文章

  • 在logback.xml中自定义动态属性的方法

    在logback.xml中自定义动态属性的方法

    这篇文章主要介绍了在logback.xml中自定义动态属性的方法,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-08-08
  • Java并发编程包中atomic的实现原理示例详解

    Java并发编程包中atomic的实现原理示例详解

    这篇文章主要给大家介绍了关于Java并发编程包中atomic的实现原理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-09-09
  • idea的easyCode的 MybatisPlus模板的配置详解

    idea的easyCode的 MybatisPlus模板的配置详解

    这篇文章主要介绍了idea的easyCode的 MybatisPlus模板的配置详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • java对xml节点属性的增删改查实现方法

    java对xml节点属性的增删改查实现方法

    下面小编就为大家带来一篇java对xml节点属性的增删改查实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-10-10
  • java中实现视频处理以及播放功能代码详解

    java中实现视频处理以及播放功能代码详解

    这篇文章主要给大家介绍了关于java中实现视频处理以及播放功能的相关资料,最近要实现一套音视频播放程序,所以这里给大家总结下,需要的朋友可以参考下
    2023-09-09
  • Java手写一个日志框架的示例代码

    Java手写一个日志框架的示例代码

    日志框架是一种用于记录和管理应用程序运行时信息的软件组件,它通常提供了一套API让开发人员能够在代码中插入日志语句,下面我们就来学习一下如何手写一个日志框架吧
    2023-12-12
  • SpringBoot异步处理全过程

    SpringBoot异步处理全过程

    这篇文章主要介绍了SpringBoot异步处理全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-06-06
  • 设置JavaScript自动提示-Eclipse/MyEclipse

    设置JavaScript自动提示-Eclipse/MyEclipse

    自动提示需要2个组件,分别是:ext-4.0.2a.jsb2||spket-1.6.16.jar,需要的朋友可以参考下
    2016-05-05
  • Java编写实现九宫格应用

    Java编写实现九宫格应用

    这篇文章主要为大家详细介绍了Java编写实现九宫格应用,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-05-05
  • Java中IO流使用FileWriter写数据基本操作详解

    Java中IO流使用FileWriter写数据基本操作详解

    这篇文章主要介绍了Java中IO流FileWriter写数据操作,FileWriter类提供了多种写入字符的方法,包括写入单个字符、写入字符数组和写入字符串等,它还提供了一些其他的方法,如刷新缓冲区、关闭文件等,需要的朋友可以参考下
    2023-10-10

最新评论