Mybatis-plus更新字段為null兩種常用方法及優(yōu)化
前言
更新時,把某些字段的值更新為null,但是目前mybatis-plus的update/updateById會忽略實體類中為null的字段,導(dǎo)致這些字段沒有更新還是原來的值。
網(wǎng)上比較常用的有兩種:
1、在實體類的屬性上增加注解:@TableField(updateStrategy = FieldStrategy.IGNORED)
/**
* 手機(jī)號
**/
@TableField(updateStrategy = FieldStrategy.IGNORED)
private String phone;
缺點:當(dāng)在其它接口更新別的字段時,本來沒有想更新這個字段,但是也會把這個字段更新為null。
2、使用LambdaUpdateWrapper的set更新
// set更新 LambdaUpdateWrapper<UserEntity> updateWrapper = Wrappers.lambdaUpdate(); updateWrapper.set(UserEntity::getPhone, null); updateWrapper.eq(UserEntity::getUserId, "0001"); userMapper.update(null, updateWrapper);
缺點:需要一個一個屬性set,比較麻煩。我平常使用的都是從DTO直接copy到Entity里面,要是updateWrapper.set的話比較繁瑣,而且有的值為null時不更新。
優(yōu)化:
還是使用LambdaUpdateWrapper的set更新,方法update(entity, updateWrapper)當(dāng)?shù)谝粋€參數(shù)實體類entity不為null時,其中entity中為null的屬性不會更新,不為null的會更新, updateWrapper.set()是不論是否為null都更新。
既可以攜程:
LambdaUpdateWrapper<UserEntity> updateWrapper = Wrappers.lambdaUpdate();
if (StringUtils.isEmpty(phone)) {
// 這個值為null,才set,不然sql里面會兩次賦值,執(zhí)行sql時報錯
updateWrapper.set(UserEntity::getPhone, null);
}
updateWrapper.eq(UserEntity::getUserId, "0001");
UserEntity entity = new UserEntity();
entity.setName("張三");
entity.setAge(null);
userMapper.update(null, updateWrapper);
說明:根據(jù)userId更新,name為張三,phone為null,而age不更新。
SQL:
update user set name = '張三', phone = null where user_id = '0001'
結(jié)論:使用update(entity, updateWrapper)更新
屬性為null不更新,使用entity保存;若屬性為null時更新表中字段為null,則用updateWrapper.set()保存數(shù)據(jù),set前需要判斷這個屬性的值為null。
總結(jié)
到此這篇關(guān)于Mybatis-plus更新字段為null兩種常用方法及優(yōu)化的文章就介紹到這了,更多相關(guān)Mybatis-plus更新字段為null內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
springboot運(yùn)行到dokcer中 dockerfile的場景分析
這篇文章主要介紹了springboot運(yùn)行到dokcer中 dockerfile,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-03-03
如何將復(fù)雜SQL轉(zhuǎn)換成Java對象的實例講解
轉(zhuǎn)換復(fù)雜SQL到Java代碼,我們需要確定數(shù)據(jù)庫連接方式和工具,使用JDBC的API來連接數(shù)據(jù)庫、執(zhí)行SQL語句,復(fù)雜SQL語句可以被拆分為多個步驟,每個步驟執(zhí)行一個特定的操作,通過將SQL語句拆分為多個步驟,我們可以更好地理解復(fù)雜SQL的邏輯,并且更容易將其轉(zhuǎn)換為Java代碼2024-05-05
空指針HttpSession異常之SpringBoot集成WebSocket的方法
文章介紹了在Spring?Boot中集成WebSocket時遇到的HttpSession為空的問題,并探討了三種解決方法,方法一涉及域名配置,方法二通過監(jiān)聽創(chuàng)建Session,而方法三是從request中獲取session并存入數(shù)據(jù),感興趣的朋友一起看看吧2025-01-01

