关于更新字段为空值——MybatisPlus框架

背景:我们在项目开发过程中,可能会经常遇到这样的问题,某个前端的字段,用户把原本有值的改为空值了,用户的意愿肯定是要去更新的,前端此时会把这个字段传"null"或空字符串,但我们后端使用框架提供的api会自动将空值跳过不去更新。

一、框架api

java 复制代码
    /**
     * 根据 ID 修改
     *
     * @param entity 实体对象
     */
    int updateById(@Param(Constants.ENTITY) T entity);

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

第二个api update方法,有误导,我一开始看到"set 条件值,可以为null",错把这个理解为可以将实体类为null字段去更新为null,后来才明白,它的本意是第一个实体类参数,可以直接传null,完全由第二个参数来控制set参数和where条件(详细可以去看mybatisPlus官网)

所以在不改mybatisPlus全局配置的前提下,上述两个update API,都不会去更新字段值为null的字段。

二、解决方案

1.在实体类添加注解

java 复制代码
      @TableField(updateStrategy = FieldStrategy.IGNORED)
       private String childJobId;

       @TableField(updateStrategy = FieldStrategy.IGNORED)
       private Integer executorTimeout;

注解枚举含义如下:

这种方法的优点就是方便,在实体类某个/某几个字段打上如上的注解,就可以将该字段字段值为null时也更新;

缺点那就是会影响所有的更新场景,关于这个实体的所有更新都会影响。

2.动态显示设置,结合 `Wrapper` 显式设置字段**

如果不想要第一种影响这个实体的所有更新场景,那就使用动态的Wrapper语句

java 复制代码
    LambdaUpdateWrapper<XxlJobInfo> updateWrapper = Wrappers.lambdaUpdate(XxlJobInfo.class)
           .eq(XxlJobInfo::getId, req.getId())
           .set(XxlJobInfo::getChildJobId, req.getChildJobId()) // 即使为 null 也会更新
           .set(XxlJobInfo::getExecutorTimeout, req.getExecutorTimeout());

       int infoUpdate = jobInfoMapper.update(null, updateWrapper);

优点:影响范围小,仅仅影响本方法中的更新,不会影响关于这个实体其他更新,其他更新方法该怎么更新还是怎么更新

缺点:繁琐,得把要更新的字段,一一设置

相关推荐
专注VB编程开发20年6 小时前
vb.net datatable新增数据时改用数组缓存
java·linux·windows
(>_<)6 小时前
java minio 分片上传工具类与测试demo
java·minio·分片上传
不想打工的码农6 小时前
MyBatis-Plus多数据源实战:被DBA追着改配置后,我肝出这份避坑指南(附动态切换源码)
java·后端
Coder_Boy_6 小时前
Deeplearning4j+ Spring Boot 电商用户复购预测案例
java·人工智能·spring boot·后端·spring
踢足球09296 小时前
寒假打卡:2026-2-7
java·开发语言·javascript
闻哥6 小时前
Kafka高吞吐量核心揭秘:四大技术架构深度解析
java·jvm·面试·kafka·rabbitmq·springboot
金牌归来发现妻女流落街头6 小时前
【Springboot基础开发】
java·spring boot·后端
考琪7 小时前
Nginx打印变量到log方法
java·运维·nginx
wangjialelele7 小时前
Linux中的进程管理
java·linux·服务器·c语言·c++·个人开发
历程里程碑7 小时前
普通数组----轮转数组
java·数据结构·c++·算法·spring·leetcode·eclipse