中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MybatisPlus怎么使用updateById()、update()將字段更新為null

發布時間:2022-08-09 14:07:06 來源:億速云 閱讀:1933 作者:iii 欄目:開發技術

這篇文章主要介紹了MybatisPlus怎么使用updateById()、update()將字段更新為null的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇MybatisPlus怎么使用updateById()、update()將字段更新為null文章都會有所收獲,下面我們一起來看看吧。

問題背景

昨晚同事找我幫他看一個問題,他使用mybatis-plus中提供的updateById方法,想將查詢結果中某個字段原本不為null的值更新為null(數據庫設計允許為null),但結果該字段更新失敗,執行更新方法后還是查詢的結果。

問題原因

mybatis-plus FieldStrategy 有三種策略:

  • IGNORED:0 忽略

  • NOT_NULL:1 非 NULL,默認策略

  • NOT_EMPTY:2 非空

而默認更新策略是NOT_NULL:非 NULL;即通過接口更新數據時數據為NULL值時將不更新進數據庫。

解決方案

針對上述問題,利用自己的項目環境(使用的mybatis-plus版本是3.1)測試了一下,總結了以下三種解決方案。

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

1. 設置全局的field-strategy

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

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

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

2. 對某個字段設置單獨的field-strategy

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

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

/**
 * 下架時間
 */
@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;
 }

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

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

3. 使用UpdateWrapper方式更新

在mybatis-plus中,除了updateById方法,還提供了一個update方法,直接使用update方法也可以將字段設置為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;
 }

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

關于“MybatisPlus怎么使用updateById()、update()將字段更新為null”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“MybatisPlus怎么使用updateById()、update()將字段更新為null”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

建瓯市| 洛扎县| 台江县| 昌江| 西乡县| 航空| 双流县| 连州市| 章丘市| 阿鲁科尔沁旗| 同仁县| 昭平县| 上犹县| 三穗县| 繁峙县| 临泉县| 利辛县| 古丈县| 贵定县| 固原市| 大城县| 杭锦旗| 界首市| 富源县| 盐边县| 襄城县| 胶州市| 松原市| 南靖县| 普洱| 延安市| 桂林市| 霍州市| 自治县| 乌恰县| 博爱县| 伊春市| 射洪县| 乌海市| 清流县| 班戈县|