国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

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

瀏覽:2日期:2023-07-24 13:07:18
問(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è)參考,也希望大家多多支持好吧啦網(wǎng)。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 久久精品国产亚洲7777小说 | 天码毛片一区二区三区入口 | 国产不卡视频在线观看 | 国产伦精品一区三区视频 | 欧美一区二区视频在线观看 | 美国全免费特一级毛片 | 很黄很色的免费视频 | 美国毛片视频 | 国产大陆亚洲精品国产 | 欧美高清日本三级人妇 | 日韩在线视频线视频免费网站 | www.黄色com | 亚洲日本一区二区三区高清在线 | 中文字幕在线视频观看 | 亚洲国产成人超福利久久精品 | 国产成人精品亚洲日本语音 | 国内一区| 一色屋成人免费精品网站 | 一级一毛片a级毛片欧美 | 国产情侣无套精品视频 | 国产精品久久久久久久久福利 | 亚洲国产日产韩国欧美综合 | 91久久综合| 免费a网址 | 欧美一级毛片欧美大尺度一级毛片 | 一级特黄aa大片欧美网站 | 人成免费a级毛片 | 一级片免费网址 | 免费国产a | 欧美jizzhd精品欧美高清 | 日本午夜小视频 | 中文字幕水野优香在线网在线 | 久久99久久精品免费思思 | 国产成人精品视频频 | 模特三级在线观看 | 久久久久网站 | 日日摸日日碰夜夜爽久久 | 精品国产亚一区二区三区 | 国产日韩精品欧美一区 | chinese宾馆自拍hd| 欧美精品日本一级特黄 |