欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mybatis-plus更新字段為null兩種常用方法及優(yōu)化

 更新時(shí)間:2024年03月30日 11:01:16   作者:王春海  
Mybatis Plus在進(jìn)行更新操作時(shí),默認(rèn)情況下是不能將字段更新為null的,如果要更新字段為null,需要進(jìn)行以下處理,這篇文章主要給大家介紹了關(guān)于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)文章

  • MyBatis實(shí)現(xiàn)分頁的兩種方式

    MyBatis實(shí)現(xiàn)分頁的兩種方式

    本文詳細(xì)比較了MyBatis中的邏輯分頁(如RowBounds)、物理分頁(基于數(shù)據(jù)庫的LIMIT/OFFSET)和插件式分頁(如PageHelper)的優(yōu)缺點(diǎn)及應(yīng)用場景,強(qiáng)調(diào)了在處理大數(shù)據(jù)量時(shí)選擇物理分頁的重要性,以及MyBatis-Plus的分頁便利性,對mybatis分頁相關(guān)知識感興趣的朋友一起看看吧
    2025-07-07
  • springboot 如何設(shè)置端口號和添加項(xiàng)目名

    springboot 如何設(shè)置端口號和添加項(xiàng)目名

    這篇文章主要介紹了springboot設(shè)置端口號和添加項(xiàng)目名的操作,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • springboot的四種啟動(dòng)方式

    springboot的四種啟動(dòng)方式

    本文主要介紹了springboot的四種啟動(dòng)方式,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • springboot運(yùn)行到dokcer中 dockerfile的場景分析

    springboot運(yùn)行到dokcer中 dockerfile的場景分析

    這篇文章主要介紹了springboot運(yùn)行到dokcer中 dockerfile,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-03-03
  • Java利用POI讀取、寫入Excel的方法指南

    Java利用POI讀取、寫入Excel的方法指南

    這篇文章主要給大家介紹了關(guān)于Java利用POI讀取、寫入Excel的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • 如何將復(fù)雜SQL轉(zhuǎn)換成Java對象的實(shí)例講解

    如何將復(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
  • Java后端配置允許跨域方式

    Java后端配置允許跨域方式

    本文介紹了在不同技術(shù)和框架中配置跨域資源共享(CORS)的方法,包括使用SpringMVC的@CrossOrigin注解、SpringBoot的全局CORS配置、SpringSecurity中的CORS集成以及手動(dòng)設(shè)置響應(yīng)頭,根據(jù)具體需求和技術(shù)棧,選擇合適的方法來確??缬蛘埱蟮陌踩院陀行?/div> 2025-02-02
  • 空指針HttpSession異常之SpringBoot集成WebSocket的方法

    空指針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ò)的問題解決

    本文主要介紹了SpringBootTest報(bào)錯(cuò)的問題解決,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2025-09-09
  • Java注解Annotation解析

    Java注解Annotation解析

    這篇文章主要為大家詳細(xì)介紹了Java注解Annotation,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-09-09

最新評論