Mybatis-Plus使用updateById()、update()將字段更新為null
問題背景
昨晚同事找我?guī)退匆粋€問題,他使用mybatis-plus中提供的updateById方法,想將查詢結(jié)果中某個字段原本不為null的值更新為null(數(shù)據(jù)庫設計允許為null),但結(jié)果該字段更新失敗,執(zhí)行更新方法后還是查詢的結(jié)果。
問題原因
mybatis-plus FieldStrategy 有三種策略:
- IGNORED:0 忽略
- NOT_NULL:1 非 NULL,默認策略
- NOT_EMPTY:2 非空
而默認更新策略是NOT_NULL:非 NULL;即通過接口更新數(shù)據(jù)時數(shù)據(jù)為NULL值時將不更新進數(shù)據(jù)庫。
解決方案
針對上述問題,利用自己的項目環(huán)境(使用的mybatis-plus版本是3.1)測試了一下,總結(jié)了以下三種解決方案。
(以下解決方案是基于直接使用mybatis-plus提供的方法使用的,如果習慣寫sql,當然你也可以直接在xml中寫sql實現(xiàn))
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,可能會影響其他業(yè)務數(shù)據(jù)的正確性。
2. 對某個字段設置單獨的field-strategy
根據(jù)具體情況,在需要更新的字段中調(diào)整驗證注解,如驗證非空:
@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; }
這種方式不影響其他方法,不需要修改全局配置,也不需要在字段上單獨加注解,所以推薦使用該方式。
到此這篇關于Mybatis-Plus使用updateById()、update()將字段更新為null的文章就介紹到這了,更多相關Mybatis-Plus 字段更新為null內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
springboot獲取properties屬性值的多種方式總結(jié)
這篇文章主要介紹了springboot獲取properties屬性值的多種方式總結(jié),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03解決idea 通過build project 手動觸發(fā)熱部署失敗的問題
在debug運行項目的過程中,并且保證(不添加方法,不修改方法名)一定的規(guī)則的情況下,可以通過build project 來手動熱部署項目,本文給大家介紹解決idea 通過build project 手動觸發(fā)熱部署失敗的問題,感興趣的朋友一起看看吧2023-12-12SpringBoot處理JSON數(shù)據(jù)方法詳解
這篇文章主要介紹了SpringBoot整合Web開發(fā)中Json數(shù)據(jù)處理,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-10-10java實現(xiàn)動態(tài)上傳多個文件并解決文件重名問題
這篇文章主要為大家詳細介紹了java實現(xiàn)動態(tài)上傳多個文件,并解決文件重名問題的方法,感興趣的小伙伴們可以參考一下2016-03-03IntelliJ IDEA(2019)安裝破解及HelloWorld案例(圖文)
這篇文章主要介紹了IntelliJ IDEA(2019)安裝破解及HelloWorld案例(圖文),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-10-10