亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2024年03月30日 11:01:16   作者:王春海  
Mybatis Plus在進行更新操作時,默認情況下是不能將字段更新為null的,如果要更新字段為null,需要進行以下處理,這篇文章主要給大家介紹了關于Mybatis-plus更新字段為null的兩種常用方法及優(yōu)化,需要的朋友可以參考下

前言

更新時,把某些字段的值更新為null,但是目前mybatis-plus的update/updateById會忽略實體類中為null的字段,導致這些字段沒有更新還是原來的值。

網上比較常用的有兩種:

1、在實體類的屬性上增加注解:@TableField(updateStrategy = FieldStrategy.IGNORED)

    /**
     * 手機號
     **/
    @TableField(updateStrategy = FieldStrategy.IGNORED)
    private String phone;

缺點:當在其它接口更新別的字段時,本來沒有想更新這個字段,但是也會把這個字段更新為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)當第一個參數實體類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);

說明:根據userId更新,name為張三,phone為null,而age不更新。
SQL:

update user set name = '張三', phone = null where user_id = '0001'

結論:使用update(entity, updateWrapper)更新

屬性為null不更新,使用entity保存;若屬性為null時更新表中字段為null,則用updateWrapper.set()保存數據,set前需要判斷這個屬性的值為null。

總結

到此這篇關于Mybatis-plus更新字段為null兩種常用方法及優(yōu)化的文章就介紹到這了,更多相關Mybatis-plus更新字段為null內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • MyBatis實現分頁的兩種方式

    MyBatis實現分頁的兩種方式

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

    springboot 如何設置端口號和添加項目名

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

    springboot的四種啟動方式

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

    springboot運行到dokcer中 dockerfile的場景分析

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

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

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

    如何將復雜SQL轉換成Java對象的實例講解

    轉換復雜SQL到Java代碼,我們需要確定數據庫連接方式和工具,使用JDBC的API來連接數據庫、執(zhí)行SQL語句,復雜SQL語句可以被拆分為多個步驟,每個步驟執(zhí)行一個特定的操作,通過將SQL語句拆分為多個步驟,我們可以更好地理解復雜SQL的邏輯,并且更容易將其轉換為Java代碼
    2024-05-05
  • Java后端配置允許跨域方式

    Java后端配置允許跨域方式

    本文介紹了在不同技術和框架中配置跨域資源共享(CORS)的方法,包括使用SpringMVC的@CrossOrigin注解、SpringBoot的全局CORS配置、SpringSecurity中的CORS集成以及手動設置響應頭,根據具體需求和技術棧,選擇合適的方法來確保跨域請求的安全性和有效性
    2025-02-02
  • 空指針HttpSession異常之SpringBoot集成WebSocket的方法

    空指針HttpSession異常之SpringBoot集成WebSocket的方法

    文章介紹了在Spring?Boot中集成WebSocket時遇到的HttpSession為空的問題,并探討了三種解決方法,方法一涉及域名配置,方法二通過監(jiān)聽創(chuàng)建Session,而方法三是從request中獲取session并存入數據,感興趣的朋友一起看看吧
    2025-01-01
  • SpringBootTest報錯的問題解決

    SpringBootTest報錯的問題解決

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

    Java注解Annotation解析

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

最新評論