解决springjpa的局部更新字段问题

 更新时间:2021年01月29日 15:55:48   作者:罚站的孩子  
这篇文章主要介绍了解决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);

这样一个映射就完成我们的需求了。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。

相关文章

  • Spring Security如何在Servlet中执行

    Spring Security如何在Servlet中执行

    这篇文章主要介绍了Spring Security如何在Servlet中执行,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-04-04
  • java时区转换的理解及示例详解

    java时区转换的理解及示例详解

    这篇文章主要介绍了java时区转换的理解及示例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • java自定义切面增强方式(关于自定义注解aop)

    java自定义切面增强方式(关于自定义注解aop)

    这篇文章主要介绍了java自定义切面增强方式(关于自定义注解aop),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • Java详解AVL树的应用

    Java详解AVL树的应用

    AVL树是高度平衡的二叉树,它的特点是AVL树中任何节点的两个子树的高度最大差别为1,本文主要给大家介绍了Java如何实现AVL树,需要的朋友可以参考下
    2022-07-07
  • jar包加密方案分享

    jar包加密方案分享

    如何对jar包进行加密呢?其实没有想象中的那么困难,有一款开源工具已经提供了较为完善的加密方案,这款开源工具的名字叫做xjar。接下来我们就看一下使用xjar工具给jar包加密有多么的容易。
    2021-06-06
  • springboot多租户设计过程图解

    springboot多租户设计过程图解

    这篇文章主要介绍了springboot多租户设计过程图解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12
  • BigDecimal的toString()、toPlainString()和toEngineeringString()区别及用法详解

    BigDecimal的toString()、toPlainString()和toEngineeringString()区

    使用BigDecimal进行打印的时候,经常会对BigDecimal提供的三个toString方法感到好奇,以下整理3个toString方法的区别及用法,需要的朋友可以参考下
    2023-08-08
  • spring boot配置拦截器代码实例

    spring boot配置拦截器代码实例

    这篇文章主要介绍了spring boot配置拦截器代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-11-11
  • 详解Java中的四种引用类型(强软弱虚)

    详解Java中的四种引用类型(强软弱虚)

    Java中的引用类型主要分为四种,分别是强引用、软引用、弱引用和虚引用,这篇文章主要为大家详细介绍了四者的使用与区别,需要的小伙伴可以参考下
    2023-10-10
  • Junit 5中@ParameterizedTest与@EnumSource结合使用

    Junit 5中@ParameterizedTest与@EnumSource结合使用

    今天小编就为大家分享一篇关于Junit 5中@ParameterizedTest与@EnumSource结合使用,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12

最新评论