Mybatis-plus null值更新不生效問題解決
默認的mybatic-plus執(zhí)行updateById等操作時,如果相關(guān)字段內(nèi)容是null值,不會自動進行更新的,這是個坑,需要注意。
問題原因
mybatis-plus FieldStrategy 有三種策略:
- IGNORED:0 忽略
- NOT_NULL:1 非 NULL,默認策略
- NOT_EMPTY:2 非空
而默認更新策略是NOT_NULL
:非 NULL;即通過接口更新數(shù)據(jù)時數(shù)據(jù)為NULL值時將不更新進數(shù)據(jù)庫。
解決方案
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
這樣做是全局性配置,會對所有的字段都忽略判斷,如果一些字段不想要修改,但是傳值的時候沒有傳遞過來,就會被更新為null,可能會影響其他業(yè)務(wù)數(shù)據(jù)的正確性。
2. 對某個字段設(shè)置單獨的field-strategy
根據(jù)具體情況,在需要更新的字段中調(diào)整驗證注解,如驗證非空:
@TableField(strategy=FieldStrategy.NOT_EMPTY)
這樣的話,我們只需要在需要更新為null的字段上,設(shè)置忽略策略,如下:
@TableField(strategy = FieldStrategy.IGNORED) private String dutyJson;
在更新代碼中,我們直接使用mybatis-plus中的updateById方法便可以更新成功,如下:
/** * updateById更新字段為null * @param id * @return */ @Override public boolean updateProductById(Integer id) { InsuranceProduct insuranceProduct = Optional.ofNullable(articleMapper.selectById(id)).orElseThrow(RuntimeException::new); insuranceProduct.setDutyJson(null); insuranceProductMapper.updateById(insuranceProduct); }
使用上述方法,如果需要這樣處理的字段較多,那么就需要涉及對各個字段上都添加該注解,顯得有些麻煩了。那么,可以考慮使用第三種方法,不需要在字段上加注解也能更新成功。
3. 使用UpdateWrapper方式更新(推薦使用)
在mybatis-plus中,除了updateById方法,還提供了一個update方法,直接使用update方法也可以將字段設(shè)置為null,代碼如下:
/** * 根據(jù)商品唯一編碼,更新商品責(zé)任的dutyjson */ public int updateProduct(String productCode) { InsuranceProduct old = lambdaQuery().eq(InsuranceProduct::getProductCode, productCode).one(); UpdateWrapper<InsuranceProduct> wrapper = new UpdateWrapper<>(); wrapper.lambda().eq(InsuranceProduct::getProductCode, productCode) .set(InsuranceProduct::getDutyJson, null) .eq(InsuranceProduct::getDeleted, 0); return getBaseMapper().update(old, wrapper); }
這種方式不影響其他方法,不需要修改全局配置,也不需要在字段上單獨加注解,所以推薦使用該方式。
到此這篇關(guān)于Mybatis-plus null值更新不生效問題解決的文章就介紹到這了,更多相關(guān)Mybatis-plus null值更新不生效內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring?Boot指標監(jiān)控及日志管理示例詳解
Spring Boot Actuator可以幫助程序員監(jiān)控和管理SpringBoot應(yīng)用,比如健康檢查、內(nèi)存使用情況統(tǒng)計、線程使用情況統(tǒng)計等,這篇文章主要介紹了Spring?Boot指標監(jiān)控及日志管理,需要的朋友可以參考下2023-11-11IDEA中如何查找jar包之間的依賴關(guān)系并忽略依賴的某個包
這篇文章主要介紹了IDEA中如何查找jar包之間的依賴關(guān)系并忽略依賴的某個包?本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-08-08淺談為什么阿里巴巴要禁用Executors創(chuàng)建線程池
這篇文章主要介紹了淺談為什么阿里巴巴要禁用Executors創(chuàng)建線程池,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02基于Java+SSM實現(xiàn)電影院購票系統(tǒng)
今天小編給大家?guī)硪豢頢SM的電影院售票系統(tǒng),非常不錯的一個項目,是學(xué)習(xí)?javaweb編程必備。文中的示例代碼講解詳細,需要的可以參考一下2022-04-04