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

Mybatis-Plus使用updateById()、update()將字段更新為null

 更新時(shí)間:2022年08月09日 11:55:31   作者:好好生活_  
本文主要介紹了Mybatis-Plus使用updateById()、update()將字段更新為null,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

問題背景

昨晚同事找我?guī)退匆粋€(gè)問題,他使用mybatis-plus中提供的updateById方法,想將查詢結(jié)果中某個(gè)字段原本不為null的值更新為null(數(shù)據(jù)庫(kù)設(shè)計(jì)允許為null),但結(jié)果該字段更新失敗,執(zhí)行更新方法后還是查詢的結(jié)果。

問題原因

mybatis-plus FieldStrategy 有三種策略:

  • IGNORED:0 忽略
  • NOT_NULL:1 非 NULL,默認(rèn)策略
  • NOT_EMPTY:2 非空

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

解決方案

針對(duì)上述問題,利用自己的項(xiàng)目環(huán)境(使用的mybatis-plus版本是3.1)測(cè)試了一下,總結(jié)了以下三種解決方案。

(以下解決方案是基于直接使用mybatis-plus提供的方法使用的,如果習(xí)慣寫sql,當(dāng)然你也可以直接在xml中寫sql實(shí)現(xiàn))

1. 設(shè)置全局的field-strategy

#properties文件格式:
mybatis-plus.global-config.db-config.field-strategy=ignored

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

這樣做是全局性配置,會(huì)對(duì)所有的字段都忽略判斷,如果一些字段不想要修改,但是傳值的時(shí)候沒有傳遞過來,就會(huì)被更新為null,可能會(huì)影響其他業(yè)務(wù)數(shù)據(jù)的正確性。

2. 對(duì)某個(gè)字段設(shè)置單獨(dú)的field-strategy

根據(jù)具體情況,在需要更新的字段中調(diào)整驗(yàn)證注解,如驗(yàn)證非空:
@TableField(strategy=FieldStrategy.NOT_EMPTY)

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

/**
 * 下架時(shí)間
 */
@TableField(strategy = FieldStrategy.IGNORED)
private LocalDateTime offlineTime;

在更新代碼中,我們直接使用mybatis-plus中的updateById方法便可以更新成功,如下:

 /**
  * updateById更新字段為null
  * @param id
  * @return
  */
 @Override
 public boolean updateArticleById(Integer id) {
     Article article = Optional.ofNullable(articleMapper.selectById(id)).orElseThrow(RuntimeException::new);
     article.setContent("try mybatis plus update null again");
     article.setPublishTime(LocalDateTime.now().plusHours(8));
     article.setOfflineTime(null);
     int i = articleMapper.updateById(article);
     return i==1;
 }

使用上述方法,如果需要這樣處理的字段較多,那么就需要涉及對(duì)各個(gè)字段上都添加該注解,顯得有些麻煩了。

那么,可以考慮使用第三種方法,不需要在字段上加注解也能更新成功。

3. 使用UpdateWrapper方式更新

在mybatis-plus中,除了updateById方法,還提供了一個(gè)update方法,直接使用update方法也可以將字段設(shè)置為null,代碼如下:

 /**
  * update更新字段為null
  * @param id
  * @return
  */
 @Override
 public boolean updateArticleById(Integer id) {
     Article article = Optional.ofNullable(articleMapper.selectById(id)).orElseThrow(RuntimeException::new);
     LambdaUpdateWrapper<Article> updateWrapper = new LambdaUpdateWrapper<>();
     updateWrapper.set(Article::getOfflineTime,null);
     updateWrapper.set(Article::getContent,"try mybatis plus update null");
     updateWrapper.set(Article::getPublishTime,LocalDateTime.now().plusHours(8));
     updateWrapper.eq(Article::getId,article.getId());
     int i = articleMapper.update(article, updateWrapper);
     return i==1;
 }

這種方式不影響其他方法,不需要修改全局配置,也不需要在字段上單獨(dú)加注解,所以推薦使用該方式。

到此這篇關(guān)于Mybatis-Plus使用updateById()、update()將字段更新為null的文章就介紹到這了,更多相關(guān)Mybatis-Plus 字段更新為null內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • springboot獲取properties屬性值的多種方式總結(jié)

    springboot獲取properties屬性值的多種方式總結(jié)

    這篇文章主要介紹了springboot獲取properties屬性值的多種方式總結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • JSON,AJAX,Maven入門基礎(chǔ)

    JSON,AJAX,Maven入門基礎(chǔ)

    這篇文章主要介紹了JSON,AJAX和Maven基礎(chǔ),如何使用AJAX讀取Json數(shù)組里面的數(shù)據(jù),感興趣的小伙伴們可以參考一下,希望能夠幫助到你
    2021-07-07
  • 解決idea 通過build project 手動(dòng)觸發(fā)熱部署失敗的問題

    解決idea 通過build project 手動(dòng)觸發(fā)熱部署失敗的問題

    在debug運(yùn)行項(xiàng)目的過程中,并且保證(不添加方法,不修改方法名)一定的規(guī)則的情況下,可以通過build project 來手動(dòng)熱部署項(xiàng)目,本文給大家介紹解決idea 通過build project 手動(dòng)觸發(fā)熱部署失敗的問題,感興趣的朋友一起看看吧
    2023-12-12
  • SpringBoot處理JSON數(shù)據(jù)方法詳解

    SpringBoot處理JSON數(shù)據(jù)方法詳解

    這篇文章主要介紹了SpringBoot整合Web開發(fā)中Json數(shù)據(jù)處理,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-10-10
  • spring事物傳播propagation類別含義詳解

    spring事物傳播propagation類別含義詳解

    這篇文章主要介紹了spring事物傳播propagation類別含義詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-12-12
  • Java多線程 樂觀鎖和CAS機(jī)制詳細(xì)

    Java多線程 樂觀鎖和CAS機(jī)制詳細(xì)

    這篇文章主要介紹了Java多線程 樂觀鎖和CAS機(jī)制,樂觀鎖是對(duì)于數(shù)據(jù)沖突保持一種樂觀態(tài)度,操作數(shù)據(jù)時(shí)不會(huì)對(duì)操作的數(shù)據(jù)進(jìn)行加鎖,需要的朋友可以參考下
    2021-10-10
  • java實(shí)現(xiàn)動(dòng)態(tài)上傳多個(gè)文件并解決文件重名問題

    java實(shí)現(xiàn)動(dòng)態(tài)上傳多個(gè)文件并解決文件重名問題

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)動(dòng)態(tài)上傳多個(gè)文件,并解決文件重名問題的方法,感興趣的小伙伴們可以參考一下
    2016-03-03
  • IntelliJ IDEA(2019)安裝破解及HelloWorld案例(圖文)

    IntelliJ IDEA(2019)安裝破解及HelloWorld案例(圖文)

    這篇文章主要介紹了IntelliJ IDEA(2019)安裝破解及HelloWorld案例(圖文),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • 深入理解Java設(shè)計(jì)模式之訪問者模式

    深入理解Java設(shè)計(jì)模式之訪問者模式

    這篇文章主要介紹了JAVA設(shè)計(jì)模式之訪問者模式的的相關(guān)資料,文中示例代碼非常詳細(xì),供大家參考和學(xué)習(xí),感興趣的朋友可以了解
    2021-11-11
  • SpringMVC實(shí)現(xiàn)返回響應(yīng)的項(xiàng)目實(shí)踐

    SpringMVC實(shí)現(xiàn)返回響應(yīng)的項(xiàng)目實(shí)踐

    本文主要介紹了SpringMVC實(shí)現(xiàn)返回響應(yīng)的項(xiàng)目實(shí)踐,包含返回靜態(tài)頁面,返回?cái)?shù)據(jù),返回html片段等實(shí)例,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-02-02

最新評(píng)論