Mybatis-plus更新字段為null兩種常用方法及優(yōu)化
前言
更新時(shí),把某些字段的值更新為null,但是目前mybatis-plus的update/updateById會忽略實(shí)體類中為null的字段,導(dǎo)致這些字段沒有更新還是原來的值。
網(wǎng)上比較常用的有兩種:
1、在實(shí)體類的屬性上增加注解:@TableField(updateStrategy = FieldStrategy.IGNORED)
/**
* 手機(jī)號
**/
@TableField(updateStrategy = FieldStrategy.IGNORED)
private String phone;
缺點(diǎn):當(dāng)在其它接口更新別的字段時(shí),本來沒有想更新這個(gè)字段,但是也會把這個(gè)字段更新為null。
2、使用LambdaUpdateWrapper的set更新
// set更新 LambdaUpdateWrapper<UserEntity> updateWrapper = Wrappers.lambdaUpdate(); updateWrapper.set(UserEntity::getPhone, null); updateWrapper.eq(UserEntity::getUserId, "0001"); userMapper.update(null, updateWrapper);
缺點(diǎn):需要一個(gè)一個(gè)屬性set,比較麻煩。我平常使用的都是從DTO直接copy到Entity里面,要是updateWrapper.set的話比較繁瑣,而且有的值為null時(shí)不更新。
優(yōu)化:
還是使用LambdaUpdateWrapper的set更新,方法update(entity, updateWrapper)當(dāng)?shù)谝粋€(gè)參數(shù)實(shí)體類entity不為null時(shí),其中entity中為null的屬性不會更新,不為null的會更新, updateWrapper.set()是不論是否為null都更新。
既可以攜程:
LambdaUpdateWrapper<UserEntity> updateWrapper = Wrappers.lambdaUpdate();
if (StringUtils.isEmpty(phone)) {
// 這個(gè)值為null,才set,不然sql里面會兩次賦值,執(zhí)行sql時(shí)報(bào)錯(cuò)
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時(shí)更新表中字段為null,則用updateWrapper.set()保存數(shù)據(jù),set前需要判斷這個(gè)屬性的值為null。
總結(jié)
到此這篇關(guān)于Mybatis-plus更新字段為null兩種常用方法及優(yōu)化的文章就介紹到這了,更多相關(guān)Mybatis-plus更新字段為null內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
springboot 如何設(shè)置端口號和添加項(xiàng)目名
這篇文章主要介紹了springboot設(shè)置端口號和添加項(xiàng)目名的操作,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08
springboot運(yùn)行到dokcer中 dockerfile的場景分析
這篇文章主要介紹了springboot運(yùn)行到dokcer中 dockerfile,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03
如何將復(fù)雜SQL轉(zhuǎn)換成Java對象的實(shí)例講解
轉(zhuǎn)換復(fù)雜SQL到Java代碼,我們需要確定數(shù)據(jù)庫連接方式和工具,使用JDBC的API來連接數(shù)據(jù)庫、執(zhí)行SQL語句,復(fù)雜SQL語句可以被拆分為多個(gè)步驟,每個(gè)步驟執(zhí)行一個(gè)特定的操作,通過將SQL語句拆分為多個(gè)步驟,我們可以更好地理解復(fù)雜SQL的邏輯,并且更容易將其轉(zhuǎn)換為Java代碼2024-05-05
本文介紹了在不同技術(shù)和框架中配置跨域資源共享(CORS)的方法,包括使用SpringMVC的@CrossOrigin注解、SpringBoot的全局CORS配置、SpringSecurity中的CORS集成以及手動(dòng)設(shè)置響應(yīng)頭,根據(jù)具體需求和技術(shù)棧,選擇合適的方法來確??缬蛘埱蟮陌踩院陀行?/div> 2025-02-02
空指針HttpSession異常之SpringBoot集成WebSocket的方法
文章介紹了在Spring?Boot中集成WebSocket時(shí)遇到的HttpSession為空的問題,并探討了三種解決方法,方法一涉及域名配置,方法二通過監(jiān)聽創(chuàng)建Session,而方法三是從request中獲取session并存入數(shù)據(jù),感興趣的朋友一起看看吧2025-01-01
SpringBootTest報(bào)錯(cuò)的問題解決
本文主要介紹了SpringBootTest報(bào)錯(cuò)的問題解決,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2025-09-09最新評論

