Mybatis Plus字段为空值时未更新问题及解决

 更新时间:2026年05月15日 08:48:47   作者:讓丄帝愛伱  
在使用MybatisPlus的UpdateById()方法时,如果字段从前台传入的数据为空值,则该字段不会得到更新,可以通过使用@TableField注解的fill属性、全局配置update-strategy属性或使用UpdateWrapper类来解决此问题

问题:

使用Mybatis Plus提供的封装方法UpdateById()时,字段从前台传入的数据为空值,但是执行方法后该字段未得到更新。

以前使用原生Mybatis生成的Update方法,是有对值是否为空的判断,如果为空就不加入到update table set语句内,那么Mybatis Plus是不是会有类似于@TableField、@TableId这样的注解,能解决该问题呢

解决:

方案一 注解方式

进入@TableField注解的相关内容。

在该注解的属性描述内,有这样一个字段——“fill”,字段自动填充策略。

fillEnumFieldFill.DEFAULT字段自动填充策略

它决定了在执行新增或修改方法时,有这个注解的字段需要怎样将数据进行填充,FieldFill的相关的属性,官方描述如下:

描述
DEFAULT默认不处理
INSERT插入时填充字段
UPDATE更新时填充字段
INSERT_UPDATE插入和更新时填充字段

默认值是DEFAULT,默认不处理,即本次出现的问题——新增、修改该字段为空时,将不自动填充即不列入语句,如:

insert into shop_item(shop_price) values(xxxx);
update shop_item set shop_price = xxxx;
@Data
@TableName("shop_item")
public class ShopItem implements Serializable {
 
 
     private static final long serialVersionUID = 1L;
 
    /**
     * 编号
     */
    @TableId(type= IdType.INPUT)
    private String id;
 
    /**
     * 物品名称
     */
    private String itemName;
 
    /**
     * 物品价格
     */
    @TableField(fill = FieldFill.UPDATE)
    private Double itemPrice;
 
    /**
    *    添加人编号
    */
    private String addUserId;
 
    /**
    *    添加时间
    */
    private Date addTime;
}

在itemPrice属性的顶上加上@TableField(fill = FieldFill.UPDATE)后,在执行一遍查看SQL

update 
    shop_item 
set 
    item_name = 'iPhone',
    item_price = ''
where 
id = '361E8C48-6699-4ED5-83C4-7C9D98747C2C';

方案二 全局配置

根据方案一中,FieldStrategy 的三种策略:IGNORED、NOT_NULL、NOT_EMPTY,

可以在 application.yml 配置文件中注入配置 GlobalConfiguration 属性 update-strategy,

将 update-strategy 策略调整为 IGNORED,即忽略判断策略。即可调整全局的验证策略。

如下所示:

# yml 配置:
mybatis-plus:
  global-config:
    db-config:
      update-strategy: IGNORED

全局性配置会对所有的字段都忽略判断,如果有特殊字段处理,可以单独配置,修改字段的策略。

设定全局配置,可以减少一个一个字段去指定增加的麻烦。

方案三:使用 UpdateWrapper (3.x) 更新

mp 提供了 UpdateWrapper 类简化更新的操作,

针对方法级进行操作,只需操作其更新方法,相比较方案一和方案二,方案三影响范围较小。

由于 BaseMapper 的继承 Mapper ,在 BaseMapper

/**
 * 根据 whereEntity 条件,更新记录
 *
 * @param entity        实体对象 (set 条件值,可以为 null)
 * @param updateWrapper 实体对象封装操作类(可以为 null,里面的 entity 用于生成 where 语句)
 */
int update(@Param(Constants.ENTITY) T entity, @Param(Constants.WRAPPER) Wrapper<T> updateWrapper);

看出,实体对象可以 set 条件值且为可以为 null,说明有两种方法可以实现更新操作(采用 lambda 表达式):

  • 将需要更新的字段,设置到 entity 中
  • 将 entity设置为 null ,将需要更新的字段设置到 UpdateWrapper 中
mapper.update(
    null,
    Wrappers.<User>lambdaUpdate()
       .set(User::getAge, 3)
       .set(User::getName, "mp")
       .set(User::getEmail, null) //把email设置成null
       .eq(User::getId, 2)
);

总结

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

相关文章

  • Liquibase 在 Spring Boot 中的使用详细介绍

    Liquibase 在 Spring Boot 中的使用详细介绍

    Liquibase 提供了灵活的变更集机制,支持创建表、修改列、填充数据、回滚变更等多种操作,本文将通过多个丰富的示例,详细讲解如何在 Spring Boot项目中使用 Liquibase,感兴趣的朋友跟随小编一起看看吧
    2024-12-12
  • Java类加载器ClassLoader详解

    Java类加载器ClassLoader详解

    这篇文章主要介绍了Java类加载器ClassLoader,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-06-06
  • SpringBoot动态定时功能实现方案详解

    SpringBoot动态定时功能实现方案详解

    在SpringBoot项目中简单使用定时任务,不过由于要借助cron表达式且都提前定义好放在配置文件里,不能在项目运行中动态修改任务执行时间,实在不太灵活。现在我们就来实现可以动态修改cron表达式的定时任务,感兴趣的可以了解一下
    2022-11-11
  • Java在PowerPoint中自动化创建图表轻松实现数据可视化

    Java在PowerPoint中自动化创建图表轻松实现数据可视化

    在当今数据驱动的时代,高效地将数据转化为直观的视觉信息变得至关重要,本文将深入探讨如何利用 Spire.Presentation for Java 库,以编程方式自动化创建和美化 PowerPoint 图表,从而大幅提升您的工作效率,实现真正的自动化 PPT
    2025-10-10
  • String.join()方法示例详解

    String.join()方法示例详解

    String.join() 方法是连接指定数组的元素或集合的成员,在每个元素或成员之间使用指定的分隔符,这篇文章主要介绍了String.join()方法示例详解,需要的朋友可以参考下
    2024-01-01
  • IDEA无法启动,重装后也无法启动的解决方案

    IDEA无法启动,重装后也无法启动的解决方案

    在IDEA中调整idea64.exe.vmoptions文件后导致关闭后启动IDEA失败,解决方法是调整C盘下的idea64.exe.vmoptions文件,将参数与IDEA目录下的文件一致
    2025-11-11
  • 详解Java 10 var关键字和示例教程

    详解Java 10 var关键字和示例教程

    在本文中,我将通过示例介绍新的Java SE 10特性——“var”类型。你将学习如何在代码中正确使用它,以及在什么情况下不能使用它,需要的朋友可以参考下
    2018-10-10
  • 详解Java并发之Condition

    详解Java并发之Condition

    这篇文章主要介绍了Java并发编程之Condition,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-06-06
  • Arrays.sort如何实现降序排序

    Arrays.sort如何实现降序排序

    这篇文章主要介绍了Arrays.sort如何实现降序排序问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • java反射总结实例详解

    java反射总结实例详解

    这篇文章主要结合实例形式分析了介绍了java基于反射得到对象属性值的方法,Class类,基本数据类型,类的反射等,需要的朋友可以参考下
    2017-04-04

最新评论