前言
之前有个解决方案是关于beanUtil.Copy之后,还需要处理才能使两个对象合并,今天偶尔发现还有更好用的分发,所以特此share一下。这是一个BeanUtil.Merge
方法,JAVA合并对象属性
,把对象的非空属性合成到目标对象上
。
作为对之前文章《BeanUtils.copyProperties忽略null值/只拷贝非null属性》的完善和提升
解决方案
BeanUtil源码,。if(defaultValue!=null && !"".equals(defaultValue))
可以使用StringUtil.isNotEmpty(defaultValue)
来判断,如果你有对应的方法,替换是最好的,否则也不会太影响使用。 如果你需要处理Integer或者int一些0导致的问题,这里可以新增一个&& 0!=defaultValue
,根据自己项目的实际情况进行编辑
/**
* BeanMerge,对象属性合并(比beanCopy好用)
* @Author zhengkai.blog.csdn.net
*/
public static <M> void merge(M target, M destination) throws Exception {
//获取目标bean
BeanInfo beanInfo = Introspector.getBeanInfo(target.getClass());
// 遍历所有属性
for (PropertyDescriptor descriptor : beanInfo.getPropertyDescriptors()) {
// 如果是可写属性
if (descriptor.getWriteMethod() != null) {
Object defaultValue = descriptor.getReadMethod().invoke(destination);
//可以使用StringUtil.isNotEmpty(defaultValue)来判断
if(defaultValue!=null && !"".equals(defaultValue)){
//用非空的defaultValue值覆盖到target去
descriptor.getWriteMethod().invoke(target, defaultValue);
}
}
}
}
使用方法。假设现在有一个数据库对象a,我有一个新的编辑对象b,b只编辑了部分a的字段,那么需要把b合并到a中,则使用merge(a,b)
;
//场景来自excel导入:存在则更新部分信息,不存在则新增
Cert certOld = certMapper.selectOne(new QueryWrapper<Cert>().eq("cert_number",t.getCertNumber()));
if(certOld==null){
//不存在则插入
certMapper.insert(t);
resultList.add(t.getCertName()+":新增成功");
}else{
merge(certOld,t);
log.info("合并后的cert对象:{}",JSON.toJSONString(certOld));
certMapper.updateById(certOld);
log.info("xxx");
resultList.add(t.getCertName()+":更新成功");
}