關(guān)于Mybatis-plus設(shè)置字段為空的正確寫法
Mybatis-plus設(shè)置字段為空的寫法
使用Mybatis-plus在進(jìn)行字段更新操作設(shè)置字段值為null,使用如下的操作語句:
LambdaUpdateWrapper<Entity> wrapper = new LambdaUpdateWrapper<>(); wrapper.set(Entity::getField,null); wrapper.eq(Entity::getId,1);
發(fā)現(xiàn)打印出來的sql只有更新條件,沒有field=null,導(dǎo)致更新報(bào)錯(cuò)。
這是為什么呢?這是因?yàn)镸ybatis-plus在更新的時(shí)候做了null判斷,默認(rèn)不更新為null的傳參字段,但業(yè)務(wù)如此,我們應(yīng)該怎么寫呢?
方法一:調(diào)整全局的驗(yàn)證策略
注入配置 GlobalConfiguration 屬性 fieldStrategy
方法二:調(diào)整字段驗(yàn)證注解
根據(jù)具體情況,在需要更新的字段中調(diào)整驗(yàn)證注解,如驗(yàn)證非空:
@TableField(strategy=FieldStrategy.NOT_EMPTY)
方法三:使用 UpdateWrapper
使用以下方法來進(jìn)行更新操作:
例1.
?? ?this.mapper.update(null, ? ? ? ? ? ? ? ? Wrappers.<Entity>lambdaUpdate() ? ? ? ? ? ? ? ? .set(Entity::getField, null) ? ? ? ? ? ? ? ? .eq(Entity::getId, id));
例2.
?? ?UpdateWrapper<Entity> updateWrapper = new UpdateWrapper<>(); ?? ?updateWrapper.set("field", null); ?? ?updateWrapper.eq("id", 2) ?? ?this.update(updateWrapper);
這樣我們就很容易的處理了使用Mybatis-plus設(shè)置字段為空不生效的問題了。
MyBatis-Plus更新字段為null 不生效
在使用mybatis-plus時(shí),發(fā)現(xiàn)當(dāng)前端傳入的值為null值時(shí),結(jié)果無論怎么操作后端都不執(zhí)行更新null字段的操作,數(shù)據(jù)庫中的需要被更新為null的字段沒有被更新。
原因
通過sql查看發(fā)現(xiàn)null字段未在sql中執(zhí)行,經(jīng)過查閱發(fā)現(xiàn)mybaits-plus在更新時(shí)排除了null字段
MyBatis-Plus對(duì)字段的驗(yàn)證策略導(dǎo)致的,MyBatis-Plus默認(rèn)進(jìn)?了不是全量更新的策略,默認(rèn)忽略為null 的字段的
解決辦法
1.如果要更新的字段是String類型
可以把前端傳入的null改為空字符串(“”),這樣mybati-plus就不會(huì)忽略更新該字段
2.使用mybatis-plus的字段注入
在可能為空的Model類字段上方加@TableField(fill = FieldFill.INSERT_UPDATE),問題解決。
如:
/** * 介紹說明(非必填) */ @TableField(fill = FieldFill.UPDATE) private String explanation;
共有四種可選,默認(rèn)不處理
3.修改MyBatis-Plus 全局默認(rèn)策略
缺點(diǎn):這樣做會(huì)對(duì)所有的字段都忽略判斷,如果一些字段不想要修改,但是傳值的時(shí)候沒有傳遞過來,就會(huì)被更新為null
mybatis-plus: global-config: #字段策略 0:"忽略判斷",1:"非 NULL 判斷",2:"非空判斷" field-strategy: 0
4.修改實(shí)體類注解,改變字段的忽略判斷
缺點(diǎn):需要注意數(shù)據(jù)庫字段是否設(shè)置為 非null ,如果為非null 也更新不成功
@TableField( updateStrategy = FieldStrategy.IGNORED) private Date settleTime;
( updateStrategy = FieldStrategy.IGNORED) private Date settleTime;
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
MyBatis的通俗理解:SqlSession.getMapper()源碼解讀
這篇文章主要介紹了MyBatis的通俗理解:SqlSession.getMapper()源碼解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03Struts2實(shí)現(xiàn)上傳單個(gè)文件功能
這篇文章主要為大家詳細(xì)介紹了Struts2實(shí)現(xiàn)上傳單個(gè)文件功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06Springboot整合quartz產(chǎn)生錯(cuò)誤及解決方案
這篇文章主要介紹了Springboot整合quartz產(chǎn)生錯(cuò)誤及解決方案,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-06-06SpringBoot實(shí)現(xiàn)攔截器、過濾器、監(jiān)聽器過程解析
這篇文章主要介紹了SpringBoot實(shí)現(xiàn)攔截器、過濾器、監(jiān)聽器過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12springboot項(xiàng)目部署在linux上運(yùn)行的兩種方式小結(jié)
這篇文章主要介紹了springboot項(xiàng)目部署在linux上運(yùn)行的兩種方式小結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07手把手教你如何在idea中搭建SpringBoot項(xiàng)目
這篇文章主要介紹了如何搭建一個(gè)SpringBoot項(xiàng)目,包括環(huán)境準(zhǔn)備、創(chuàng)建新項(xiàng)目、探索項(xiàng)目結(jié)構(gòu)以及展望未來,通過詳細(xì)的步驟和實(shí)用的技巧,幫助開發(fā)者快速上手SpringBoot開發(fā),文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2025-02-02