Browse Source

fix:修复工厂三方物料导入重复问题

dist.1.3.0
pref_mail@163.com 9 months ago
parent
commit
acecaf2f3d
  1. 79
      blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/excel/BasicdataFactoryCategoryImporter.java

79
blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/excel/BasicdataFactoryCategoryImporter.java

@ -83,30 +83,77 @@ public class BasicdataFactoryCategoryImporter implements ExcelImporter<Basicdata
/** /**
* 验证三方物料是否已经存在 * 验证三方物料是否已经存在
*
* @param allBasicdataFactoryCategoryEntities * @param allBasicdataFactoryCategoryEntities
* @param datum * @param datum
*/ */
private void checkAllBasicdataFactoryCategoryEntities(List<BasicdataFactoryCategoryEntity> allBasicdataFactoryCategoryEntities, BasicdataFactoryCategoryExcel datum) { private void checkAllBasicdataFactoryCategoryEntities(List<BasicdataFactoryCategoryEntity> allBasicdataFactoryCategoryEntities, BasicdataFactoryCategoryExcel datum) {
for (BasicdataFactoryCategoryEntity allBasicdataFactoryCategoryEntity : allBasicdataFactoryCategoryEntities) { for (BasicdataFactoryCategoryEntity allBasicdataFactoryCategoryEntity : allBasicdataFactoryCategoryEntities) {
if (allBasicdataFactoryCategoryEntity.getBrand().equals(datum.getBrand()) && allBasicdataFactoryCategoryEntity.getCategory().equals(datum.getCategory()) ){ String equalString = buildEqualString(allBasicdataFactoryCategoryEntity);
if(ObjectUtil.isNotEmpty(allBasicdataFactoryCategoryEntity.getFirsts())&& ObjectUtil.isNotEmpty(allBasicdataFactoryCategoryEntity.getSeconds())&& ObjectUtil.isNotEmpty(allBasicdataFactoryCategoryEntity.getThirds())){ String equalString2 = buildEqualString2(datum);
if(allBasicdataFactoryCategoryEntity.getFirsts().equals(datum.getFirsts()) && allBasicdataFactoryCategoryEntity.getSeconds().equals(datum.getSeconds()) && allBasicdataFactoryCategoryEntity.getThirds().equals(datum.getThirds())){ if (equalString2.equals(equalString)) {
throw new ServiceException("品牌:" + datum.getBrand() + " 品类:" + datum.getCategory() + "一级品:"+datum.getFirsts()+" 二级品:"+datum.getSeconds()+" 三级品:"+datum.getThirds()+"已存在相同的配置内容"); throw new ServiceException("品牌:" + datum.getBrand() + " 品类:" + datum.getCategory() + "已存在相同的配置内容");
}
}else if(ObjectUtil.isNotEmpty(allBasicdataFactoryCategoryEntity.getFirsts())&& ObjectUtil.isNotEmpty(allBasicdataFactoryCategoryEntity.getSeconds())){
if (allBasicdataFactoryCategoryEntity.getFirsts().equals(datum.getFirsts()) && allBasicdataFactoryCategoryEntity.getSeconds().equals(datum.getSeconds())){
throw new ServiceException("品牌:" + datum.getBrand() + " 品类:" + datum.getCategory() + "一级品:"+datum.getFirsts()+" 二级品:"+datum.getSeconds()+"已存在相同的配置内容");
}
} else if (ObjectUtil.isNotEmpty(allBasicdataFactoryCategoryEntity.getFirsts())) {
if (allBasicdataFactoryCategoryEntity.getFirsts().equals(datum.getFirsts())){
throw new ServiceException("品牌:" + datum.getBrand() + " 品类:" + datum.getCategory() + "一级品:"+datum.getFirsts()+"已存在相同的配置内容");
}
}
} }
} }
} }
/**
* 构建字符串
*
* @param allBasicdataFactoryCategoryEntity
* @return
*/
private String buildEqualString(BasicdataFactoryCategoryEntity allBasicdataFactoryCategoryEntity) {
StringBuilder stringBuffer = new StringBuilder();
stringBuffer.append(allBasicdataFactoryCategoryEntity.getBrand()).append(allBasicdataFactoryCategoryEntity.getCategory());
if (ObjectUtil.isNotEmpty(allBasicdataFactoryCategoryEntity.getFirsts())) {
stringBuffer.append(allBasicdataFactoryCategoryEntity.getFirsts());
} else {
stringBuffer.append("-");
}
if (ObjectUtil.isNotEmpty(allBasicdataFactoryCategoryEntity.getSeconds())) {
stringBuffer.append(allBasicdataFactoryCategoryEntity.getSeconds());
} else {
stringBuffer.append("-");
}
if (ObjectUtil.isNotEmpty(allBasicdataFactoryCategoryEntity.getThirds())) {
stringBuffer.append(allBasicdataFactoryCategoryEntity.getThirds());
} else {
stringBuffer.append("-");
}
return stringBuffer.toString();
}
/**
* 构建匹配字符串
* @param datum
* @return
*/
private String buildEqualString2(BasicdataFactoryCategoryExcel datum) {
StringBuilder stringBuffer = new StringBuilder();
stringBuffer.append(datum.getBrand()).append(datum.getCategory());
if (ObjectUtil.isNotEmpty(datum.getFirsts())) {
stringBuffer.append(datum.getFirsts());
} else {
stringBuffer.append("-");
}
if (ObjectUtil.isNotEmpty(datum.getSeconds())) {
stringBuffer.append(datum.getSeconds());
} else {
stringBuffer.append("-");
}
if (ObjectUtil.isNotEmpty(datum.getThirds())) {
stringBuffer.append(datum.getThirds());
} else {
stringBuffer.append("-");
}
return stringBuffer.toString();
}
} }

Loading…
Cancel
Save