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

解決springjpa的局部更新字段問(wèn)題

 更新時(shí)間:2021年01月29日 15:55:48   作者:罰站的孩子  
這篇文章主要介紹了解決springjpa的局部更新字段問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

問(wèn)題描述:

使用springjpa更新數(shù)據(jù)時(shí),有時(shí)候我們需要更新部分字段,對(duì)已有的內(nèi)容保持不變,通常我們可以通過(guò)Spring提供的bean工具類BeanUtils來(lái)實(shí)現(xiàn)

解決方法:

BeanUtils復(fù)制對(duì)象,BeanUtils中的構(gòu)造方法屬性中可以通過(guò)傳入更新時(shí)忽略的屬性值來(lái)實(shí)現(xiàn)選擇性復(fù)制原對(duì)象的字段。更新部分字段時(shí),我們僅需要傳入復(fù)制后的字段即可。

解析和實(shí)現(xiàn):

BeanUtils的構(gòu)造方法:

具體更新部分字段的步驟:

查詢出待更新對(duì)象的原有信息

通過(guò)傳入的更新的象去復(fù)制產(chǎn)生一個(gè)新對(duì)象,其中新對(duì)象中為null的字段不需要更新。

執(zhí)行更新操作,操作對(duì)象時(shí)步驟2得出的復(fù)制對(duì)象。

代碼如下:

public Result update(@RequestBody AppScene appScene, @PathVariable String id ){
 AppScene target = appSceneService.findById(id); //數(shù)據(jù)庫(kù)查出待更新對(duì)象
 BeanUtils.copyProperties(appScene,target,getNullPropertyNames(appScene)); //使用更新對(duì)象的非空值去覆蓋待更新對(duì)象
 appSceneService.update(target ); //執(zhí)行更新操作
 return new Result(true,StatusCode.OK,"修改成功");
}

其中涉及的getNullPropertyNames方法作為工具類存在,具體如下:

public static String[] getNullPropertyNames (Object source) {
 final BeanWrapper src = new BeanWrapperImpl(source);
 java.beans.PropertyDescriptor[] pds = src.getPropertyDescriptors();
 Set<String> emptyNames = new HashSet<String>();
 for(java.beans.PropertyDescriptor pd : pds) {
 Object srcValue = src.getPropertyValue(pd.getName());
 if (srcValue == null) emptyNames.add(pd.getName());
 }
 String[] result = new String[emptyNames.size()];
 return emptyNames.toArray(result);
 }

更新:

這是之前剛開(kāi)始學(xué)習(xí)框架的時(shí)候遇到的問(wèn)題,其實(shí)這個(gè)問(wèn)題spring早就提供了對(duì)應(yīng)的方法去解決,它提供了對(duì)應(yīng)bean拷貝的方法BeanUtils.copyProperties,通過(guò)傳入不同的值決定是否要忽略非空屬性值的拷貝,現(xiàn)在已經(jīng)沒(méi)有必要自己手寫(xiě)了。

補(bǔ)充:Java Jpa選擇性更新、部分字段更新工具類

使用Jpa自帶的Save方法更新實(shí)體類時(shí),會(huì)覆蓋數(shù)據(jù)庫(kù)中實(shí)體類原有內(nèi)容。如果我們只想更新一部分字段或是選擇性的更新,就只能另辟蹊徑了。

這個(gè)工具類很好地彌補(bǔ)了這個(gè)不足,對(duì)于待更新實(shí)體類中有內(nèi)容的字段會(huì)更新,為空的字段會(huì)采用原數(shù)據(jù)庫(kù)中內(nèi)容,下面是工具類代碼(附使用方法)。

工具類代碼:

import org.springframework.beans.BeanWrapper;
import org.springframework.beans.BeanWrapperImpl;
import java.util.HashSet;
import java.util.Set;
/**
 * jpa 部分字段更新方法
 */
public class UpdateColumnUtil {
 public static String[] getNullPropertyNames(Object source) {
  final BeanWrapper src = new BeanWrapperImpl(source);
  java.beans.PropertyDescriptor[] pds = src.getPropertyDescriptors();
  Set<String> emptyNames = new HashSet<>();
  for (java.beans.PropertyDescriptor pd : pds) {
   Object srcValue = src.getPropertyValue(pd.getName());
   if (srcValue == null) emptyNames.add(pd.getName());
  }
  String[] result = new String[emptyNames.size()];
  return emptyNames.toArray(result);
 }
}

使用方法:

//首先從數(shù)據(jù)庫(kù)查出待更新對(duì)象
Customer target = customerService.findById(customer.getCustId());
//使用更新對(duì)象的非空值去覆蓋待更新對(duì)象
BeanUtils.copyProperties(customer, target, UpdateColumnUtil.getNullPropertyNames(customer));
//執(zhí)行更新操作
save = customerService.save(target);

這樣一個(gè)映射就完成我們的需求了。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

相關(guān)文章

  • Spring Security如何在Servlet中執(zhí)行

    Spring Security如何在Servlet中執(zhí)行

    這篇文章主要介紹了Spring Security如何在Servlet中執(zhí)行,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • java時(shí)區(qū)轉(zhuǎn)換的理解及示例詳解

    java時(shí)區(qū)轉(zhuǎn)換的理解及示例詳解

    這篇文章主要介紹了java時(shí)區(qū)轉(zhuǎn)換的理解及示例詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • java自定義切面增強(qiáng)方式(關(guān)于自定義注解aop)

    java自定義切面增強(qiáng)方式(關(guān)于自定義注解aop)

    這篇文章主要介紹了java自定義切面增強(qiáng)方式(關(guān)于自定義注解aop),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • Java詳解AVL樹(shù)的應(yīng)用

    Java詳解AVL樹(shù)的應(yīng)用

    AVL樹(shù)是高度平衡的二叉樹(shù),它的特點(diǎn)是AVL樹(shù)中任何節(jié)點(diǎn)的兩個(gè)子樹(shù)的高度最大差別為1,本文主要給大家介紹了Java如何實(shí)現(xiàn)AVL樹(shù),需要的朋友可以參考下
    2022-07-07
  • jar包加密方案分享

    jar包加密方案分享

    如何對(duì)jar包進(jìn)行加密呢?其實(shí)沒(méi)有想象中的那么困難,有一款開(kāi)源工具已經(jīng)提供了較為完善的加密方案,這款開(kāi)源工具的名字叫做xjar。接下來(lái)我們就看一下使用xjar工具給jar包加密有多么的容易。
    2021-06-06
  • springboot多租戶設(shè)計(jì)過(guò)程圖解

    springboot多租戶設(shè)計(jì)過(guò)程圖解

    這篇文章主要介紹了springboot多租戶設(shè)計(jì)過(guò)程圖解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-12-12
  • BigDecimal的toString()、toPlainString()和toEngineeringString()區(qū)別及用法詳解

    BigDecimal的toString()、toPlainString()和toEngineeringString()區(qū)

    使用BigDecimal進(jìn)行打印的時(shí)候,經(jīng)常會(huì)對(duì)BigDecimal提供的三個(gè)toString方法感到好奇,以下整理3個(gè)toString方法的區(qū)別及用法,需要的朋友可以參考下
    2023-08-08
  • spring boot配置攔截器代碼實(shí)例

    spring boot配置攔截器代碼實(shí)例

    這篇文章主要介紹了spring boot配置攔截器代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • 詳解Java中的四種引用類型(強(qiáng)軟弱虛)

    詳解Java中的四種引用類型(強(qiáng)軟弱虛)

    Java中的引用類型主要分為四種,分別是強(qiáng)引用、軟引用、弱引用和虛引用,這篇文章主要為大家詳細(xì)介紹了四者的使用與區(qū)別,需要的小伙伴可以參考下
    2023-10-10
  • Junit 5中@ParameterizedTest與@EnumSource結(jié)合使用

    Junit 5中@ParameterizedTest與@EnumSource結(jié)合使用

    今天小編就為大家分享一篇關(guān)于Junit 5中@ParameterizedTest與@EnumSource結(jié)合使用,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2018-12-12

最新評(píng)論