欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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)文章

  • springboot實現(xiàn)單文件和多文件上傳

    springboot實現(xiàn)單文件和多文件上傳

    這篇文章主要為大家詳細介紹了springboot實現(xiàn)單文件和多文件上傳,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-11-11
  • 教你怎么實現(xiàn)java語言的在線編譯

    教你怎么實現(xiàn)java語言的在線編譯

    這篇文章主要介紹了教你怎么實現(xiàn)java語言的在線編譯,文中有非常詳細的代碼示例,對正在學(xué)習(xí)java的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-04-04
  • 在IDEA中使用debug工具去運行java程序的實現(xiàn)步驟

    在IDEA中使用debug工具去運行java程序的實現(xiàn)步驟

    調(diào)試工具(debug工具)是一種用于幫助程序員識別和修復(fù)程序中的錯誤的工具,它們提供了一系列的功能,幫助程序員在代碼執(zhí)行的過程中跟蹤和檢測問題,本文將給大家介紹使用debug工具去運行java程序的實現(xiàn)步驟,需要的朋友可以參考下
    2024-04-04
  • Spring Cloud zuul自定義統(tǒng)一異常處理實現(xiàn)方法

    Spring Cloud zuul自定義統(tǒng)一異常處理實現(xiàn)方法

    這篇文章主要介紹了Spring Cloud zuul自定義統(tǒng)一異常處理實現(xiàn),需要的朋友可以參考下
    2018-02-02
  • 如何調(diào)試報表插件

    如何調(diào)試報表插件

    在項目開發(fā)過程中插件調(diào)試非常的麻煩,需要修改里面的代碼,編譯出class,需要重新打包插件。然后把之前的刪除,重新安裝最新的。調(diào)試過程比較繁瑣,而且不能調(diào)試,十分的不方便,這篇文章主要介紹的是調(diào)試報表插件的方法,需要的朋友可以參考下
    2015-07-07
  • java解析xml文本的示例方法

    java解析xml文本的示例方法

    這篇文章主要為大家詳細介紹了java解析xml文本的相關(guān)方法,文中的示例代碼講解詳細,具有一定的借鑒價值,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-12-12
  • Java 控制流程、大數(shù)值、數(shù)組

    Java 控制流程、大數(shù)值、數(shù)組

    這篇文章主要給大家介紹的是Java 控制流程、大數(shù)值、數(shù)組的一些相關(guān)自來哦,感興趣的小伙伴可以參考下面文章的具體內(nèi)容,希望文章對你有所幫助
    2021-10-10
  • 深入淺出理解Java泛型的使用

    深入淺出理解Java泛型的使用

    這篇文章主要介紹了深入淺出理解Java泛型的使用,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-09-09
  • Maven引入外部jar的幾種方法(小結(jié))

    Maven引入外部jar的幾種方法(小結(jié))

    這篇文章主要介紹了Maven引入外部jar的幾種方法(小結(jié)),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-08-08
  • java正則表達式驗證工具類

    java正則表達式驗證工具類

    這篇文章主要介紹了java正則表達式驗證工具類,可以校驗電話號碼,身份證號碼,日期格式,URL,email等等,需要的小伙伴參考下吧。
    2015-03-03

最新評論