亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Mybatis-plus更新Null字段的四種方法

 更新時間:2025年03月12日 09:25:17   作者:剽悍一小兔  
在項目開發(fā)過程中,經(jīng)常會使用Mybatis-plus的updateById()方法,快速將接收道德參數(shù)或者查詢結(jié)果中原本不為null的字段更新為null,這個時候使用updateById()并不能實現(xiàn)這個操作,不會報錯,但是對應(yīng)的字段并沒有更新為null,所以本文介紹了Mybatis-plus更新Null字段的方法

本文介紹【Mybatis-plus】updateById()方法不能更新字段為null的原因及解決辦法。

一、問題描述

在日常項目開發(fā)過程中,經(jīng)常會使用Mybatis-plus的updateById()方法,快速將接收道德參數(shù)或者查詢結(jié)果中原本不為null的字段更新為null,并且該字段在數(shù)據(jù)庫中可為null,這個時候使用updateById()并不能實現(xiàn)這個操作,不會報錯,但是對應(yīng)的字段并沒有更新為null。

二、問題原因

Mybatis-plus的字段策略(FieldStrategy)有三種策略:

IGNORED:0 忽略

NOT_NULL:1 非 NULL,默認(rèn)策略

NOT_EMPTY:2 非空

而默認(rèn)的更新策略是NOT_NULL:非NULL; 即通過接口更新數(shù)據(jù)時數(shù)據(jù)為NULL值時將不更新進數(shù)據(jù)庫。

三、解決方案

1.直接在mapper.xml中寫sql:

 update table A set 字段a = null where 字段b = 條件

2.設(shè)置全局的FieldStrategy

在配置文件中修改全局策略

properties文件格式:

mybatis-plus.global-config.db-config.field-strategy=ignored

#yml文件格式:
mybatis-plus:
  global-config:
      #字段策略 0:"忽略判斷",1:"非 NULL 判斷",2:"非空判斷"
    field-strategy: 0

這樣做是進行全局配置,在更新時會忽略對所有字段的判斷。但是如果一些字段沒有傳值過來,會被直接更新為null,可能會影響其它業(yè)務(wù)數(shù)據(jù)的準(zhǔn)確性。不推薦使用此方法。

3.對指定的字段單獨設(shè)置field-strategy

根據(jù)具體情況,在需要更新的字段中調(diào)整驗證注解,如驗非空:

@TableField(strategy=FieldStrategy.NOT_EMPTY)

這樣的話,我們只需要在需要更新為null的字段上,設(shè)置忽略策略,如下:

@TableField(updateStrategy = FieldStrategy.IGNORED)
private String updateBy;

設(shè)置好了之后,在更新時就可以直接使用mybatis-plus中的updateById方法就可以成功將字段更新為null,但是這樣做存在一定的弊端,就是當(dāng)需要這樣處理的字段比較多時,要給對應(yīng)的字段都要添加上這樣的注解。

4.使用update方法結(jié)合UpdateWrapper方式更新

User user=userService.lambdaQuery().eq(User::getUserId,userId).one();
if(user!=null){
    userService.update(user,new UpdateWrapper<User>().lambda()
               .set(User::getUserName,null)
               .eq(User::getUserId,user.getUserId()));
}

這種方法不會影響其它方法,不需要修改全局配置,也不需要在字段上單獨加注解,只需要在使用的時候設(shè)置一下要修改的字段為null就可以更新成功,推薦使用方法4。

拓展:Mybatis-Plus更新時間字段不生效

一、背景

Mybatis-Plus是在Mybatis的基礎(chǔ)上只做增強不做改變,主要是為簡化開發(fā)。項目的背景是使用的就是Mybatis-Plus,但是在運行項目過程中發(fā)現(xiàn)一個問題,當(dāng)使用Mybatis-Plus進行數(shù)據(jù)的更新的時候,更新字段沒有按照我們所預(yù)想的進行對應(yīng)的時間的更新。
創(chuàng)建這個字段的語句如下所示:

 `update_time` timestamp NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新時間'

二、原因分析

使用Mybatis-Plus的更新方法,進行對應(yīng)數(shù)據(jù)實體的更新,比如使用如下方法:

XXX.updateById()
// ....... 等等方法

這些方法使用之后,發(fā)現(xiàn)沒有對updateTime字段數(shù)據(jù)進行更新。

原因分析:

當(dāng)selectByld從數(shù)據(jù)庫取出舊數(shù)據(jù),然后修改自己想修改的字段后調(diào)用updateById,會發(fā)現(xiàn)updateTime字段不會更新,這是因為selectByld可以取出updateTime的舊值,更新時填充策路會判斷屬性已有值,不進行自動填充,因此updateTime不會自動更新。而且官方目前沒有直接提供強制更新的方法。

查看fillStrategy方法源碼,我們也可以看到只有屬性沒有被填充值,才會執(zhí)行set方法。

三、解決辦法

解決方法一:更新時設(shè)置更新時間

	TDZopenOrder openOrder = openOrderService.getById(orderId);
	openOrder.setOrderId(washOrderId);
	openOrder.setUpdateTime(LocalDateTime.now());
	openOrder.updateById()

解決方法二:實體上設(shè)置更新時間

	public class TDZopenOrder {
	    @ApiModelProperty("更新時間")
	    @TableField(update = "now()")
	    private LocalDateTime updateTime;
	}

到此這篇關(guān)于Mybatis-plus更新Null字段的方法的文章就介紹到這了,更多相關(guān)Mybatis-plus更新Null字段內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 深入理解Spring Boot屬性配置文件

    深入理解Spring Boot屬性配置文件

    這篇文章主要給大家深入的介紹了關(guān)于Spring Boot屬性配置文件的相關(guān)資料,文中介紹的很詳細(xì),相信對大家具有一定的參考借鑒價值,需要的朋友們下面來一起看看吧。
    2017-02-02
  • Spring Security表單配置過程分步講解

    Spring Security表單配置過程分步講解

    SpringSecurity的配置基于WebSecurityConfigurerAdapter的實現(xiàn)類,我們這里主要講基本配置,即configure(HttpSecurity http)方法的配置,其實大都有默認(rèn)值,我們可以直接用默認(rèn)值,也可以自己設(shè)置
    2023-01-01
  • spring異步service中處理線程數(shù)限制詳解

    spring異步service中處理線程數(shù)限制詳解

    這篇文章主要給大家介紹了關(guān)于spring異步service中處理線程數(shù)限制的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用spring具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • Java通過自定義類加載器實現(xiàn)類隔離

    Java通過自定義類加載器實現(xiàn)類隔離

    類隔離是一種通過類加載器實現(xiàn)加載所需類的實現(xiàn)方式,使得不同版本類間隔離,避免了使用沖突問題。本文將通過自定義的類加載器實現(xiàn)類隔離,感興趣的可以了解一下
    2022-08-08
  • 詳解Java中的final關(guān)鍵字

    詳解Java中的final關(guān)鍵字

    子類可以在父類的基礎(chǔ)上改寫父類內(nèi)容,為了避免這種隨意改寫的情況,Java提供了final 關(guān)鍵字,用于修飾不可改變內(nèi)容。本文就來詳細(xì)說說final關(guān)鍵字的使用,需要的可以參考一下
    2022-10-10
  • ocp開閉原則_動力節(jié)點Java學(xué)院整理

    ocp開閉原則_動力節(jié)點Java學(xué)院整理

    這篇文章主要為大家詳細(xì)介紹了ocp開閉原則的相關(guān)資料,ocp開閉原則指導(dǎo)我們?nèi)绾谓⒁粋€穩(wěn)定的、靈活的系統(tǒng),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • Java實現(xiàn)高效隨機數(shù)算法的示例代碼

    Java實現(xiàn)高效隨機數(shù)算法的示例代碼

    這篇文章主要介紹了Java實現(xiàn)高效隨機數(shù)算法的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-02-02
  • IDEA源碼修改器JarEditor使用(反編譯-打包一步到位)

    IDEA源碼修改器JarEditor使用(反編譯-打包一步到位)

    JarEditor是一個IDEA插件,用于修改jar包中的類文件,它允許用戶在不解壓jar包的情況下,直接在IDEA中編輯和修改類文件的源碼,修改完成后,可以一鍵編譯并生成新的jar包,替換原jar包
    2025-01-01
  • Lombok插件的安裝與簡單使用步驟

    Lombok插件的安裝與簡單使用步驟

    這篇文章主要介紹了Lombok插件的安裝與簡單使用步驟,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03
  • JAVA冒泡排序和二分查找的實現(xiàn)

    JAVA冒泡排序和二分查找的實現(xiàn)

    本文詳細(xì)介紹了JAVA冒泡排序和二分查找的實現(xiàn),雖然這兩種算法比較簡單,但是確實我們必須需要掌握的。下面來看看。
    2016-07-07

最新評論