温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

springjpa中出现局部更新字段如何解决

发布时间:2021-01-29 17:15:38 来源:亿速云 阅读:154 作者:Leah 栏目:开发技术

springjpa中出现局部更新字段如何解决?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

问题描述:

使用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);

关于springjpa中出现局部更新字段如何解决问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI