Mybatis-plus更新Null字段的四種方法
本文介紹【Mybatis-plus】updateById()方法不能更新字段為null的原因及解決辦法。
一、問題描述
在日常項目開發(fā)過程中,經(jīng)常會使用Mybatis-plus的updateById()方法,快速將接收道德參數(shù)或者查詢結(jié)果中原本不為null的字段更新為null,并且該字段在數(shù)據(jù)庫中可為null,這個時候使用updateById()并不能實現(xiàn)這個操作,不會報錯,但是對應(yīng)的字段并沒有更新為null。
二、問題原因
Mybatis-plus的字段策略(FieldStrategy)有三種策略:
IGNORED:0 忽略
NOT_NULL:1 非 NULL,默認(rèn)策略
NOT_EMPTY:2 非空
而默認(rèn)的更新策略是NOT_NULL:非NULL; 即通過接口更新數(shù)據(jù)時數(shù)據(jù)為NULL值時將不更新進數(shù)據(jù)庫。
三、解決方案
1.直接在mapper.xml中寫sql:
update table A set 字段a = null where 字段b = 條件
2.設(shè)置全局的FieldStrategy
在配置文件中修改全局策略
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ù)的準(zhǔn)確性。不推薦使用此方法。
3.對指定的字段單獨設(shè)置field-strategy
根據(jù)具體情況,在需要更新的字段中調(diào)整驗證注解,如驗非空:
@TableField(strategy=FieldStrategy.NOT_EMPTY)
這樣的話,我們只需要在需要更新為null的字段上,設(shè)置忽略策略,如下:
@TableField(updateStrategy = FieldStrategy.IGNORED) private String updateBy;
設(shè)置好了之后,在更新時就可以直接使用mybatis-plus中的updateById方法就可以成功將字段更新為null,但是這樣做存在一定的弊端,就是當(dāng)需要這樣處理的字段比較多時,要給對應(yīng)的字段都要添加上這樣的注解。
4.使用update方法結(jié)合UpdateWrapper方式更新
User user=userService.lambdaQuery().eq(User::getUserId,userId).one(); if(user!=null){ userService.update(user,new UpdateWrapper<User>().lambda() .set(User::getUserName,null) .eq(User::getUserId,user.getUserId())); }
這種方法不會影響其它方法,不需要修改全局配置,也不需要在字段上單獨加注解,只需要在使用的時候設(shè)置一下要修改的字段為null就可以更新成功,推薦使用方法4。
拓展:Mybatis-Plus更新時間字段不生效
一、背景
Mybatis-Plus是在Mybatis的基礎(chǔ)上只做增強不做改變,主要是為簡化開發(fā)。項目的背景是使用的就是Mybatis-Plus,但是在運行項目過程中發(fā)現(xiàn)一個問題,當(dāng)使用Mybatis-Plus進行數(shù)據(jù)的更新的時候,更新字段沒有按照我們所預(yù)想的進行對應(yīng)的時間的更新。
創(chuàng)建這個字段的語句如下所示:
`update_time` timestamp NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新時間'
二、原因分析
使用Mybatis-Plus的更新方法,進行對應(yīng)數(shù)據(jù)實體的更新,比如使用如下方法:
XXX.updateById() // ....... 等等方法
這些方法使用之后,發(fā)現(xiàn)沒有對updateTime字段數(shù)據(jù)進行更新。
原因分析:
當(dāng)selectByld從數(shù)據(jù)庫取出舊數(shù)據(jù),然后修改自己想修改的字段后調(diào)用updateById,會發(fā)現(xiàn)updateTime字段不會更新,這是因為selectByld可以取出updateTime的舊值,更新時填充策路會判斷屬性已有值,不進行自動填充,因此updateTime不會自動更新。而且官方目前沒有直接提供強制更新的方法。
查看fillStrategy方法源碼,我們也可以看到只有屬性沒有被填充值,才會執(zhí)行set方法。
三、解決辦法
解決方法一:更新時設(shè)置更新時間
TDZopenOrder openOrder = openOrderService.getById(orderId); openOrder.setOrderId(washOrderId); openOrder.setUpdateTime(LocalDateTime.now()); openOrder.updateById()
解決方法二:實體上設(shè)置更新時間
public class TDZopenOrder { @ApiModelProperty("更新時間") @TableField(update = "now()") private LocalDateTime updateTime; }
到此這篇關(guān)于Mybatis-plus更新Null字段的方法的文章就介紹到這了,更多相關(guān)Mybatis-plus更新Null字段內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
在IDEA中使用debug工具去運行java程序的實現(xiàn)步驟
調(diào)試工具(debug工具)是一種用于幫助程序員識別和修復(fù)程序中的錯誤的工具,它們提供了一系列的功能,幫助程序員在代碼執(zhí)行的過程中跟蹤和檢測問題,本文將給大家介紹使用debug工具去運行java程序的實現(xiàn)步驟,需要的朋友可以參考下2024-04-04Spring Cloud zuul自定義統(tǒng)一異常處理實現(xiàn)方法
這篇文章主要介紹了Spring Cloud zuul自定義統(tǒng)一異常處理實現(xiàn),需要的朋友可以參考下2018-02-02