色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

解決springjpa的局部更新字段問題

瀏覽:6日期:2023-07-24 13:07:18
問題描述:

使用springjpa更新數據時,有時候我們需要更新部分字段,對已有的內容保持不變,通常我們可以通過Spring提供的bean工具類BeanUtils來實現

解決方法:

BeanUtils復制對象,BeanUtils中的構造方法屬性中可以通過傳入更新時忽略的屬性值來實現選擇性復制原對象的字段。更新部分字段時,我們僅需要傳入復制后的字段即可。

解析和實現:

BeanUtils的構造方法:

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

查詢出待更新對象的原有信息

通過傳入的更新的象去復制產生一個新對象,其中新對象中為null的字段不需要更新。

執行更新操作,操作對象時步驟2得出的復制對象。

代碼如下:

public Result update(@RequestBody AppScene appScene, @PathVariable String id ){ AppScene target = appSceneService.findById(id); //數據庫查出待更新對象 BeanUtils.copyProperties(appScene,target,getNullPropertyNames(appScene)); //使用更新對象的非空值去覆蓋待更新對象 appSceneService.update(target ); //執行更新操作 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); }更新:

這是之前剛開始學習框架的時候遇到的問題,其實這個問題spring早就提供了對應的方法去解決,它提供了對應bean拷貝的方法BeanUtils.copyProperties,通過傳入不同的值決定是否要忽略非空屬性值的拷貝,現在已經沒有必要自己手寫了。

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

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

這個工具類很好地彌補了這個不足,對于待更新實體類中有內容的字段會更新,為空的字段會采用原數據庫中內容,下面是工具類代碼(附使用方法)。

工具類代碼:

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); }}使用方法:

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

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

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。如有錯誤或未考慮完全的地方,望不吝賜教。

標簽: Spring
相關文章:
主站蜘蛛池模板: 国产一区二区成人 | 人成午夜性刺激免费 | 国产欧美日韩另类 | 久久色精品 | 国产一区二区三区四区在线 | 亚洲国产精品成人精品软件 | 国产精品一区二区三区免费 | 亚洲三级黄| 久久成人国产精品免费 | 美国亚洲成年毛片 | 91进入蜜桃臀在线播放 | 午夜在线亚洲男人午在线 | 爱视频福利广场 | 亚洲热视频 | 最新国产一区二区精品久久 | 三级精品 | 欧美一二区视频 | 7777在线视频 | 99在线在线视频免费视频观看 | 成年人免费网站视频 | 97久久曰曰久久久 | 免费黄色毛片视频 | 国产成人精品微拍视频 | 亚洲福利精品一区二区三区 | 国产精品免费aⅴ片在线观看 | 亚洲一区二区三区在线网站 | 韩国一级免费视频 | 韩国日本一级毛片免费视频 | 欧美成人极品怡红院tv | 国产三级a三级三级天天 | 久草在线观看首页 | 天堂入口 | 男女在线免费视频 | 中国a级黄色片 | 国产成人a福利在线观看 | 色欲麻豆国产福利精品 | 91精品成人福利在线播放 | 国产一区二区三区高清 | 91亚洲成人 | 久久国产视频一区 | 人碰人碰人成人免费视频 |