MyBatis-Plus更新字段为null时,update语句为null字段不生效的解决方法

news2024/10/7 2:26:17

文章目录

  • 1.异常说明:
  • 2.原理:
  • 3.解决办法:
    • 1)修改MyBatis-Plus 全局默认策略
    • 2)修改实体类注解,改变字段的忽略判断
  • 4.字段策略全解
    • 1)官方文档
    • 2)字段策略介绍​​
      • 1、FieldStrategy作用
      • 2、FieldStrategy类型
      • 3、FieldStrategy配置
        • ① 全局策略配置
        • ② 单字段策略配置
    • 3)实战说明
      • 1、忽略判断-IGNORED

1.异常说明:

mapper.updateById()时, set为null 未生效,其他字段更新。


   puDeclareElements.setStatus(OrderEnum.DRAFTS.getType());
   puDeclareElements.setSubmitBy(null);
   puDeclareElementsService.updateById(puDeclareElements)
   

2.原理:

MyBatis-Plus对字段的验证策略导致的,MyBatis-Plus默认进了不是全量更新的策略,默认忽略为null 的字段的

3.解决办法:

1)修改MyBatis-Plus 全局默认策略

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


mybatis-plus:
  global-config:
  	#字段策略 0:"忽略判断",1:"非 NULL 判断",2:"非空判断"
    field-strategy: 0

2)修改实体类注解,改变字段的忽略判断

缺点:需要注意数据库字段是否设置为 非null ,如果为非null 也更新不成功


@TableField( updateStrategy = FieldStrategy.IGNORED)
private Date settleTime;

4.字段策略全解

1)官方文档

Mybatis-Plus中FieldStrategy说明:​ ​https://baomidou.com/pages/223848/#tableid​

2)字段策略介绍​​

1、FieldStrategy作用

Mybatis-Plus字段策略FieldStrategy的作用主要是在进行新增、更新时,根据配置的策略判断是否对实体对象的值进行空值判断,如果策略为字段不能为空,则不会对为空的字段进行赋值或更新。
同样,在进行where条件查询时,根据whereStrategy策略判断是否对字段进行空值判断,如果策略为字段不能为空,则为空的字段不会作为查询条件组装到where条件中。

三个配置,对应三种使用场景

​​insertStrategy​​ : 在insert操作时的字段策略,是否进行空值判断,插入空值
​​updateStrategy : 在update操作时的字段策略,是否进行空值判断,插入空值
​​whereStrategy : ​​在where条件组装时,是否进行控制判断,将空值作为查询条件

在这里插入图片描述

2、FieldStrategy类型

FieldStrategy的源码中,一共有5种策略类型

public enum FieldStrategy {
    IGNORED,
    NOT_NULL,
    NOT_EMPTY,
    DEFAULT,
    NEVER;

    private FieldStrategy() {
    }
}

每种策略的作用

描述
IGNORED

忽略空值判断,实体对象的字段是什么值就用什么值更新,支持null值更新操作

NOT_NULL

进行非NULL判断,也是默认策略,相当于age!=null

NOT_EMPTY

进行非空判断,主要是针对字符串类型,相当于name != null and name != ‘’

NEVER

从不更新,不管字段是否有值,都不进行更新

DEFAULT

追随全局配置

3、FieldStrategy配置

① 全局策略配置

在全局配置中,三者的默认值都是​​FieldStrategy.NOT_NULL​​,即进行空值判断,不对NULL值数据进行处理。

public DbConfig() {
    this.idType = IdType.ASSIGN_ID;
    this.tableUnderline = true;
    this.capitalMode = false;
    this.logicDeleteValue = "1";
    this.logicNotDeleteValue = "0";
    this.insertStrategy = FieldStrategy.NOT_NULL;
    this.updateStrategy = FieldStrategy.NOT_NULL;
    this.whereStrategy = FieldStrategy.NOT_NULL;
}

在spring boot中可以通过配置属性修改全局字段策略:

mybatis-plus.global-config.db-config.update-strategy=not_null
mybatis-plus.global-config.db-config.insert-strategy=not_null
mybatis-plus.global-config.db-config.where-strategy=not_null

② 单字段策略配置

在实体对象中,通过​​@TableField​​注解可以针对单个字段指定字段策略。

3)实战说明

1、忽略判断-IGNORED

@TableName(value ="user")
@Data
public class User implements Serializable {
   @TableId
   private Long id;
   private String name;
   private Integer age;
   @TableField(updateStrategy = FieldStrategy.IGNORED)
   private String email;
}

再次执行上面的单元测试:

在这里插入图片描述

PS:后面就不一一举例了。可以看官网。写的很详细。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1003240.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

iPhone照片删除了怎么恢复?宝藏方法分享!

自从养了宠物之后,天天喜欢给它拍照。在清理相册的时候不小心把很喜欢的照片给误删了,想问问大家有什么比较好的照片恢复方法吗? 大家在养了可爱的宠物之后,避免不了给自己的爱宠拍照。但是一拍可能就停不下来了,从而导…

代码随想录算法训练营day49|121. 买卖股票的最佳时机 |122.买卖股票的最佳时机II

121. 买卖股票的最佳时机 力扣题目链接 给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。 你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的日子 卖出该股票。设计一个算法来计算你所能获取的最大利润。…

气象监测站的分类及应用领域

随着全球气候变化的加剧,气象监测站的角色变得越来越重要。本文将介绍气象监测设备的分类,探讨其应用领域,帮助用户更好的理解气象监测站。 一、气象监测设备分类 气象监测设备主要包括以下几类: 自动气象站:自动气象…

vue中的 render 和 h() 详解

vue中的 render 和 h() 详解 当使用Vue.js进行前端开发时,理解和掌握"render"函数和"h()"函数是非常重要的,因为它们是Vue组件的核心构建和渲染部分 render 和 h()是在Vue.js中常用的两个概念,它们通常用于创建和渲染Vue…

【算法与数据结构】235、LeetCode二叉搜索树的最近公共祖先

文章目录 一、题目二、解法三、完整代码 所有的LeetCode题解索引,可以看这篇文章——【算法和数据结构】LeetCode题解。 一、题目 二、解法 思路分析:本题和这道题类似【算法与数据结构】236、LeetCode二叉树的最近公共祖先,相同的算法也能解…

2023-9-12 01背包问题

题目链接&#xff1a; 朴素版本 #include <iostream> #include <algorithm>using namespace std;const int N 1010;int n, m; int f[N][N]; int v[N], w[N];int main() {cin >> n >> m;for(int i 1; i < n; i) cin >> v[i] >> w[i];…

Java线上故障排查(CPU、磁盘、内存、网络、GC)+JVM性能调优监控工具+JVM常用参数和命令

CPU 原因包括业务逻辑问题(死循环)、频繁gc以及上下文切换过多。而最常见的往往是业务逻辑(或者框架逻辑)导致的&#xff0c;可以使用jstack来分析对应的堆栈情况。 使用jstack分析cpu问题 jstack主要用来查看某个Java进程内的线程堆栈信息 命令行参数说明&#xff1a; -l l…

ardupilot开发 --- 通信链路 篇

几个有意思的概图 飞控 以公司正在使用的 cuav Pixhawk V6X 为例 https://www.cuav.net/v6x/ 数传、飞控的mavlink连接 数传模块主要用于无人机于地面站共享数据&#xff0c;地面站通过数传可以获取无人机数据并且可以发送控制指令&#xff1b;与飞控的mavlink连接可以分为有…

文件压缩成压缩包,解压压缩包

压缩文件操作的工具类&#xff0c;压缩文件调用zip方法 package com.citicsc.galaxy.utils;import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.util.Enumeration…

重磅:百度李彦宏、中科院曾毅入选,《时代周刊》AI最有影响力100人!

2023年9月8日&#xff0c;《时代周刊》发布了“2023年AI领域最有影响力100人” 榜单。 榜单权威吗&#xff1f; 有必要介绍下《时代周刊》。 《Time》&#xff08;时代周刊&#xff09;,1923年创刊于纽约&#xff0c;是美国公认的最重要的新闻杂志之一。《时代周刊》以报道精彩…

mybatis 中BigDecimal中的0存为null的坑

问题点: 做mybatis的插入和修改操作时&#xff0c;java中类型为Bigdicemal时&#xff0c;且值为0时&#xff0c;存入到数据库中的值为null&#xff0c;而不是0&#xff0c;其它的非0值正常 部分代码如下: 有问题的属性 可以看到是 Begdecimal 类型,对应查出来的日志如下: 可以…

chrome控制台怎么看hover的样式

​ 1. 悬浮显示是通过css控制台的 点击styles下面的 &#xff1a;hov&#xff0c;然后选中hover就可以了 2.如果是js控制的 js 失去悬浮以后&#xff0c;浮层就会隐藏&#xff0c;这个时候选中hover是没用的。 那怎么保留悬浮的状态呢&#xff0c;直接右键&#xff0c;会弹…

【Python】从入门到上头— 多线程(9)

进程和线程的区别 详见【Java基础】多线程从入门到掌握第一节(一.多线程基础) 一. _thread模块和threading模块 Python的标准库提供了两个模块&#xff1a;_thread和threading&#xff0c;_thread是低级模块&#xff0c;threading是高级模块&#xff0c;对_thread进行了封装。…

菜单组件Menu

前面讲解了如果构建GUI界面&#xff0c;其实就是把一些GUI的组件&#xff0c;按照一定的布局放入到容器中展示就可以了。在实际开发中&#xff0c;除了主界面&#xff0c;还有一类比较重要的内容就是菜单相关组件&#xff0c;可以通过菜单相关组件很方便的使用特定的功能&#…

在历史长河中,这个震撼了我!

在一个人的一生中&#xff0c;很容易低估世界发生的变化。 科技能够用我们无法想象的方式改变世界&#xff0c;直到它们真的发生。 咱们回顾这个世界的技术史&#xff0c;有助于看清楚未来几年甚至几十年内可能发生的改变。 我们的祖辈在童年时代&#xff0c;很难想象出会有一个…

从9.10拼多多笔试第四题产生的01背包感悟

文章目录 题面基本的01背包问题本题变式 本文参考&#xff1a; 9.10拼多多笔试ak_牛客网 (nowcoder.com) 拼多多 秋招 2023.09.10 编程题目与题解 (xiaohongshu.com) 题面 拼多多9.10笔试的最后一题&#xff0c;是一道比较好的01背包变式问题&#xff0c;可以学习其解法加深对…

手搓消息队列【RabbitMQ版】

什么是消息队列&#xff1f; 阻塞队列&#xff08;Blocking Queue&#xff09;-> 生产者消费者模型 &#xff08;是在一个进程内&#xff09;所谓的消息队列&#xff0c;就是把阻塞队列这样的数据结构&#xff0c;单独提取成了一个程序&#xff0c;进行独立部署~ --------&…

工具教程【甜心转译】-双语字幕、中文语音生成(配音),打破信息差

甜心转译 &#xff08;主站&#xff09;是一款AI加持的音/视频生成双语字幕、中文语音的软件。帮助人们更容易的获取外语信息、不管是学习、还是娱乐&#xff0c;快人一步。 主要功能 字幕生成&#xff1a;只需几个简单的步骤&#xff0c;轻松生成字幕。字幕翻译&#xff1a;…

【校招VIP】java语言考点之异常

考点介绍&#xff1a; 导致程序的正常流程被中断的事件&#xff0c;叫做异常。异常是程序中的一些错误&#xff0c;但并不是所有的错误都是异常&#xff0c;并且错误有时候是可以避免的。异常发生的原因有很多&#xff0c;通常包含以下几大类: 1.用户输入了非法数据。2.要打开的…

【Python】爬虫基础

爬虫是一种模拟浏览器实现&#xff0c;用以抓取网站信息的程序或者脚本。常见的爬虫有三大类&#xff1a; 通用式爬虫&#xff1a;通用式爬虫用以爬取一整个网页的信息。 聚焦式爬虫&#xff1a;聚焦式爬虫可以在通用式爬虫爬取到的一整个网页的信息基础上只选取一部分所需的…