データツールsaveメソッドのJava JPA
- 一人でいくつかのフィールドJPA方法が更新されていないので、Saveメソッドは、データを更新することができ、それはまた、フィールドを更新するという欠点が空にアップしました。
ユーティリティクラスがある場合は、空でないデータエンティティクラスもありfindOneのJPAは、データ上にマッピングして、保存するには、次のように、それは非常に簡単になります。
import com.alibaba.druid.util.StringUtils;
import org.springframework.beans.BeanUtils;
import org.springframework.beans.BeanWrapper;
import org.springframework.beans.BeanWrapperImpl;
import java.beans.PropertyDescriptor;
import java.util.HashSet;
import java.util.Objects;
import java.util.Set;
public class UpdateUtil {
/**
* 所有为空值的属性都不copy
*
* @param source
* @param target
*/
public static void copyNullProperties(Object source, Object target) {
BeanUtils.copyProperties(source, target, getNullField(source));
}
/**
* 获取属性中为空的字段
*
* @param target
* @return
*/
private static String[] getNullField(Object target) {
BeanWrapper beanWrapper = new BeanWrapperImpl(target);
PropertyDescriptor[] propertyDescriptors = beanWrapper.getPropertyDescriptors();
Set<String> notNullFieldSet = new HashSet<>();
if (propertyDescriptors.length > 0) {
for (PropertyDescriptor p : propertyDescriptors) {
String name = p.getName();
Object value = beanWrapper.getPropertyValue(name);
if (Objects.isNull(value)) {
notNullFieldSet.add(name);
}
}
}
String[] notNullField = new String[notNullFieldSet.size()];
return notNullFieldSet.toArray(notNullField);
}
public static void main(String[] args) {
IdNameVo newvo= new IdNameVo();
newvo.setId("1");
newvo.setName("更新后的实体类");
newvo.setLevel(1);
newvo.setParentId("0");
IdNameVo old= new IdNameVo();
old.setId("1");
old.setName("更新前的实体类");
old.setLevel(2);
old.setParentId("1");
old.setIdx(4);
old.setCode("123");
System.out.println(old);
UpdateUtil.copyNullProperties(newvo,old);
System.out.println(old);
//然后直接jpa的save(vo2)就可以了
}
}
出力結果は以下のとおりです。
IdNameVo(ID = 1、名前=更新前のエンティティ・クラス、PARENTID = 1、レベル= 2、IDX = 4、子供= []、コード= 123、クーポン=ヌル、couponId =ヌル、promotionIDは=ヌル、
promotionType = NULL 、て、searchType = NULL)
IdNameVo(ID = 1、名前のエンティティクラス=更新、PARENTID = 0、レベル= 1 、IDX = 4、子供= []、コード= 123、クーポン=ヌル、couponId =ヌル、promotionIDは= ヌル、
promotionType =ヌル、て、searchType =ヌル)