From ff31a324f8db4650b4ede03c73cf788d6b3366ee Mon Sep 17 00:00:00 2001 From: zhenghaoyu Date: Mon, 14 Oct 2024 10:25:15 +0800 Subject: [PATCH 1/4] =?UTF-8?q?1.=E6=8A=A5=E8=A1=A8=E5=BC=95=E5=8C=85bug?= =?UTF-8?q?=E4=BF=AE=E5=A4=8D?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../org/springblade/common/constant/ModuleNameConstant.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/blade-biz-common/src/main/java/org/springblade/common/constant/ModuleNameConstant.java b/blade-biz-common/src/main/java/org/springblade/common/constant/ModuleNameConstant.java index d60420fe5..aab4eec75 100644 --- a/blade-biz-common/src/main/java/org/springblade/common/constant/ModuleNameConstant.java +++ b/blade-biz-common/src/main/java/org/springblade/common/constant/ModuleNameConstant.java @@ -9,7 +9,7 @@ public interface ModuleNameConstant { /** * 如果不需要 "" */ - public static final String DEVAUTH =""; + public static final String DEVAUTH ="-zhy"; /** * 工厂对接服务名称 From 9ef7863d6df8d6110676ed1625ff436aaff6c0c8 Mon Sep 17 00:00:00 2001 From: zhenghaoyu Date: Mon, 14 Oct 2024 10:25:44 +0800 Subject: [PATCH 2/4] =?UTF-8?q?1.=E6=8A=A5=E8=A1=A8=E5=BC=95=E5=8C=85bug?= =?UTF-8?q?=E4=BF=AE=E5=A4=8D?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../org/springblade/common/constant/ModuleNameConstant.java | 2 +- .../report/service/impl/ReportPackageBasicServiceImpl.java | 2 +- .../report/service/impl/ReportPackageTrunklineServiceImpl.java | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/blade-biz-common/src/main/java/org/springblade/common/constant/ModuleNameConstant.java b/blade-biz-common/src/main/java/org/springblade/common/constant/ModuleNameConstant.java index aab4eec75..d60420fe5 100644 --- a/blade-biz-common/src/main/java/org/springblade/common/constant/ModuleNameConstant.java +++ b/blade-biz-common/src/main/java/org/springblade/common/constant/ModuleNameConstant.java @@ -9,7 +9,7 @@ public interface ModuleNameConstant { /** * 如果不需要 "" */ - public static final String DEVAUTH ="-zhy"; + public static final String DEVAUTH =""; /** * 工厂对接服务名称 diff --git a/blade-service/logpm-report/src/main/java/com/logpm/report/service/impl/ReportPackageBasicServiceImpl.java b/blade-service/logpm-report/src/main/java/com/logpm/report/service/impl/ReportPackageBasicServiceImpl.java index d68f60605..95cc92a54 100644 --- a/blade-service/logpm-report/src/main/java/com/logpm/report/service/impl/ReportPackageBasicServiceImpl.java +++ b/blade-service/logpm-report/src/main/java/com/logpm/report/service/impl/ReportPackageBasicServiceImpl.java @@ -3,8 +3,8 @@ package com.logpm.report.service.impl; import com.logpm.report.entity.ReportPackageBasicEntity; import com.logpm.report.mapper.ReportPackageBasicMapper; import com.logpm.report.service.IReportPackageBasicService; -import groovy.util.logging.Slf4j; import lombok.AllArgsConstructor; +import lombok.extern.slf4j.Slf4j; import org.springblade.core.mp.base.BaseServiceImpl; import org.springframework.stereotype.Service; diff --git a/blade-service/logpm-report/src/main/java/com/logpm/report/service/impl/ReportPackageTrunklineServiceImpl.java b/blade-service/logpm-report/src/main/java/com/logpm/report/service/impl/ReportPackageTrunklineServiceImpl.java index df147d7d3..805ad0b6d 100644 --- a/blade-service/logpm-report/src/main/java/com/logpm/report/service/impl/ReportPackageTrunklineServiceImpl.java +++ b/blade-service/logpm-report/src/main/java/com/logpm/report/service/impl/ReportPackageTrunklineServiceImpl.java @@ -3,8 +3,8 @@ package com.logpm.report.service.impl; import com.logpm.report.entity.ReportPackageTrunklineEntity; import com.logpm.report.mapper.ReportPackageTrunklineMapper; import com.logpm.report.service.IReportPackageTrunklineService; -import groovy.util.logging.Slf4j; import lombok.AllArgsConstructor; +import lombok.extern.slf4j.Slf4j; import org.springblade.core.mp.base.BaseServiceImpl; import org.springframework.stereotype.Service; From 5e25010f64e5b26d864de4f0a6796a33cae9bf34 Mon Sep 17 00:00:00 2001 From: zhaoqiaobo <583671871@qq.com> Date: Mon, 14 Oct 2024 11:27:29 +0800 Subject: [PATCH 3/4] =?UTF-8?q?feat(all):=20=E4=BC=98=E5=8C=96=E9=85=8D?= =?UTF-8?q?=E9=80=81=E6=98=8E=E7=BB=86=E6=8A=A5=E8=A1=A8=E6=B6=88=E8=B4=B9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 1 删除一些不必要的逻辑,提高消费效率 --- .../report/QualityDeliverListener.java | 54 +++++++++---------- 1 file changed, 27 insertions(+), 27 deletions(-) diff --git a/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/receiver/report/QualityDeliverListener.java b/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/receiver/report/QualityDeliverListener.java index 5bc356999..6f89edced 100644 --- a/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/receiver/report/QualityDeliverListener.java +++ b/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/receiver/report/QualityDeliverListener.java @@ -7,7 +7,6 @@ import cn.hutool.core.util.StrUtil; import cn.hutool.json.JSONUtil; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.toolkit.Wrappers; -import com.logpm.basicdata.entity.BasicdataFactoryCategoryEntity; import com.logpm.basicdata.entity.BasicdataWarehouseEntity; import com.logpm.basicdata.feign.IBasicdataFactoryCategoryClient; import com.logpm.basicdata.feign.IBasicdataWarehouseClient; @@ -20,7 +19,6 @@ import com.logpm.distribution.service.IDistributionParcelListService; import com.logpm.distribution.service.IDistributionStockArticleService; import com.logpm.distribution.service.IDistributionStockListService; import com.logpm.distribution.service.IQualityDeliverService; -import com.logpm.trunkline.entity.TrunklineAdvanceDetailEntity; import com.logpm.trunkline.feign.ITrunklineAdvanceDetailClient; import com.logpm.warehouse.entity.WarehouseWayBillDetail; import com.logpm.warehouse.entity.WarehouseWaybillEntity; @@ -194,11 +192,13 @@ public class QualityDeliverListener { private void saveOrUpdate(LambdaQueryWrapper wrapper, QualityDeliverEntity qualityDeliverEntity) { QualityDeliverEntity entity = null; if (ObjectUtil.isNotEmpty(wrapper)) { + wrapper.select(QualityDeliverEntity::getId); entity = qualityDeliverService.getOne(wrapper); } if (ObjectUtil.isNotEmpty(entity)) { // 修改 - qualityDeliverService.update(qualityDeliverEntity, wrapper); + qualityDeliverEntity.setId(entity.getId()); + qualityDeliverService.updateById(qualityDeliverEntity); } else { // 新增 // 初始化基础数据 @@ -262,24 +262,24 @@ public class QualityDeliverListener { qualityDeliverEntity.setEndWarehouseInTime(stockList.getWarehousingTime()); } // 品类 - if (StrUtil.isNotEmpty(materielName) && StrUtil.isNotEmpty(brandName)) { - BasicdataFactoryCategoryEntity factoryCategoryEntity = new BasicdataFactoryCategoryEntity(); - factoryCategoryEntity.setMaterielName(materielName); - factoryCategoryEntity.setBrand(brandName); - factoryCategoryEntity.setType(2); - BasicdataFactoryCategoryEntity categoryEntity = factoryCategoryClient.findEntityByBrandAndMaterielName(factoryCategoryEntity); - factoryCategoryEntity.setType(1); - BasicdataFactoryCategoryEntity categoryEntity1 = factoryCategoryClient.findEntityByBrandAndMaterielName(factoryCategoryEntity); - if (ObjectUtil.isNotEmpty(categoryEntity)) { - qualityDeliverEntity.setCostCategoryId(categoryEntity.getCategoryId()); - qualityDeliverEntity.setCostCategory(categoryEntity.getCategory()); - } - if (ObjectUtil.isNotEmpty(categoryEntity1)) { - qualityDeliverEntity.setRevenueCategory(categoryEntity.getCategory()); - qualityDeliverEntity.setRevenueCategoryId(categoryEntity1.getCategoryId()); - } + // if (StrUtil.isNotEmpty(materielName) && StrUtil.isNotEmpty(brandName)) { + // BasicdataFactoryCategoryEntity factoryCategoryEntity = new BasicdataFactoryCategoryEntity(); + // factoryCategoryEntity.setMaterielName(materielName); + // factoryCategoryEntity.setBrand(brandName); + // factoryCategoryEntity.setType(2); + // BasicdataFactoryCategoryEntity categoryEntity = factoryCategoryClient.findEntityByBrandAndMaterielName(factoryCategoryEntity); + // factoryCategoryEntity.setType(1); + // BasicdataFactoryCategoryEntity categoryEntity1 = factoryCategoryClient.findEntityByBrandAndMaterielName(factoryCategoryEntity); + // if (ObjectUtil.isNotEmpty(categoryEntity)) { + // qualityDeliverEntity.setCostCategoryId(categoryEntity.getCategoryId()); + // qualityDeliverEntity.setCostCategory(categoryEntity.getCategory()); + // } + // if (ObjectUtil.isNotEmpty(categoryEntity1)) { + // qualityDeliverEntity.setRevenueCategory(categoryEntity.getCategory()); + // qualityDeliverEntity.setRevenueCategoryId(categoryEntity1.getCategoryId()); + // } // TODO 从入库单上查询入库时间 - } + // } } } @@ -322,13 +322,13 @@ public class QualityDeliverListener { buildWaybillInfo(qualityDeliverEntity, waybillNumber); } // 暂存单查询结算品类 - TrunklineAdvanceDetailEntity advanceDetailEntity = advanceDetailClient.findEntityByOrderPackageCode(qualityDeliverEntity.getOrderPackageCode()); - if (ObjectUtil.isNotEmpty(advanceDetailEntity)) { - qualityDeliverEntity.setCostCategoryId(advanceDetailEntity.getCostCategoryId()); - qualityDeliverEntity.setCostCategory(advanceDetailEntity.getCostCategoryName()); - qualityDeliverEntity.setRevenueCategoryId(advanceDetailEntity.getIncomeCategoryId()); - qualityDeliverEntity.setRevenueCategory(advanceDetailEntity.getIncomeCategoryName()); - } + // TrunklineAdvanceDetailEntity advanceDetailEntity = advanceDetailClient.findEntityByOrderPackageCode(qualityDeliverEntity.getOrderPackageCode()); + // if (ObjectUtil.isNotEmpty(advanceDetailEntity)) { + // qualityDeliverEntity.setCostCategoryId(advanceDetailEntity.getCostCategoryId()); + // qualityDeliverEntity.setCostCategory(advanceDetailEntity.getCostCategoryName()); + // qualityDeliverEntity.setRevenueCategoryId(advanceDetailEntity.getIncomeCategoryId()); + // qualityDeliverEntity.setRevenueCategory(advanceDetailEntity.getIncomeCategoryName()); + // } // 构建订单相关信息 buildOrderInfo(qualityDeliverEntity, qualityDeliverEntity.getWarehouseId(), qualityDeliverEntity.getOrderCode()); } From 985ab508f0631b903561ea7c207468015468d68d Mon Sep 17 00:00:00 2001 From: zhaoqiaobo <583671871@qq.com> Date: Mon, 14 Oct 2024 12:11:36 +0800 Subject: [PATCH 4/4] =?UTF-8?q?feat(all):=20=E4=BC=98=E5=8C=96=E9=85=8D?= =?UTF-8?q?=E9=80=81=E6=98=8E=E7=BB=86=E6=8A=A5=E8=A1=A8=E6=B6=88=E8=B4=B9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 1 增加公共的仓库,运单,订单查询缓存,提高消费效率 --- .../report/QualityDeliverListener.java | 103 +++++++++++++----- 1 file changed, 77 insertions(+), 26 deletions(-) diff --git a/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/receiver/report/QualityDeliverListener.java b/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/receiver/report/QualityDeliverListener.java index 6f89edced..0e94eea93 100644 --- a/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/receiver/report/QualityDeliverListener.java +++ b/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/receiver/report/QualityDeliverListener.java @@ -3,6 +3,7 @@ package com.logpm.distribution.receiver.report; import cn.hutool.core.collection.CollUtil; import cn.hutool.core.convert.Convert; import cn.hutool.core.util.ObjectUtil; +import cn.hutool.core.util.RandomUtil; import cn.hutool.core.util.StrUtil; import cn.hutool.json.JSONUtil; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; @@ -30,6 +31,7 @@ import org.jetbrains.annotations.Nullable; import org.springblade.common.constant.report.ReportConstants; import org.springblade.common.enums.BizOperationEnums; import org.springblade.common.enums.PackageTypeEnums; +import org.springblade.core.redis.cache.BladeRedis; import org.springframework.amqp.core.ExchangeTypes; import org.springframework.amqp.rabbit.annotation.Exchange; import org.springframework.amqp.rabbit.annotation.Queue; @@ -79,6 +81,9 @@ public class QualityDeliverListener { @Resource private IWarehouseWaybillDetailClient waybillDetailClient; + @Resource + private BladeRedis redisCache; + @RabbitListener(bindings = @QueueBinding( value = @Queue(name = ReportConstants.REPORT_QUALITY_DELIVER_QUEUE, durable = "true"), exchange = @Exchange(name = ReportConstants.REPORT_QUALITY_DELIVER_EXCHANGE, type = ExchangeTypes.TOPIC), @@ -97,9 +102,9 @@ public class QualityDeliverListener { if (ObjectUtil.equals(PackageTypeEnums.CMP.getCode(), conditions)) { // 定制品 LambdaQueryWrapper wrapper = Wrappers.lambdaQuery(); - if(ObjectUtil.isNotEmpty(qualityDeliverEntity.getId())){ + if (ObjectUtil.isNotEmpty(qualityDeliverEntity.getId())) { wrapper.eq(QualityDeliverEntity::getId, qualityDeliverEntity.getId()); - }else{ + } else { wrapper.eq(QualityDeliverEntity::getOrderPackageCode, qualityDeliverEntity.getOrderPackageCode()); } wrapper.lt(QualityDeliverEntity::getBizStatus, 110); @@ -115,9 +120,9 @@ public class QualityDeliverListener { } else if (ObjectUtil.equals(PackageTypeEnums.LTL.getCode(), conditions)) { // 零担 LambdaQueryWrapper wrapper = Wrappers.lambdaQuery(); - if(ObjectUtil.isNotEmpty(qualityDeliverEntity.getId())){ + if (ObjectUtil.isNotEmpty(qualityDeliverEntity.getId())) { wrapper.eq(QualityDeliverEntity::getId, qualityDeliverEntity.getId()); - }else{ + } else { wrapper.eq(QualityDeliverEntity::getOrderCode, qualityDeliverEntity.getOrderCode()) .eq(QualityDeliverEntity::getCategory, qualityDeliverEntity.getCategory()); } @@ -214,7 +219,7 @@ public class QualityDeliverListener { if (ObjectUtil.equals(PackageTypeEnums.CMP.getCode(), conditions)) { // 订制品 // 构建订制品基础信息 - DistributionParcelListEntity parcelListEntity = parcelListService.selectByOrderPackageCode(qualityDeliverEntity.getOrderPackageCode(), qualityDeliverEntity.getWarehouseId()); + DistributionParcelListEntity parcelListEntity = getDistributionParcelListEntity(qualityDeliverEntity.getOrderPackageCode(), qualityDeliverEntity.getWarehouseId()); buildCmpBasicInfo(qualityDeliverEntity, parcelListEntity); } if (ObjectUtil.equals(PackageTypeEnums.INV.getCode(), conditions)) { @@ -236,6 +241,11 @@ public class QualityDeliverListener { } } + private DistributionParcelListEntity getDistributionParcelListEntity(String orderPackageCode, Long warehouseId) { + DistributionParcelListEntity parcelListEntity = parcelListService.selectByOrderPackageCode(orderPackageCode, warehouseId); + return parcelListEntity; + } + private void buildInvBasicInfo(QualityDeliverEntity qualityDeliverEntity) { String materielName = qualityDeliverEntity.getMaterielName(); DistributionStockListEntity stockListEntity = new DistributionStockListEntity(); @@ -249,7 +259,7 @@ public class QualityDeliverListener { String brandName = stockList.getBrandName(); String sourceType = stockList.getSourceType(); if (StrUtil.equals(sourceType, "1")) { - DistributionParcelListEntity parcelListEntity = parcelListService.selectByOrderPackageCode(qualityDeliverEntity.getOrderPackageCode(), qualityDeliverEntity.getWarehouseId()); + DistributionParcelListEntity parcelListEntity = getDistributionParcelListEntity(qualityDeliverEntity.getOrderPackageCode(), qualityDeliverEntity.getWarehouseId()); buildCmpBasicInfo(qualityDeliverEntity, parcelListEntity); } else { qualityDeliverEntity.setBrandName(brandName); @@ -268,17 +278,17 @@ public class QualityDeliverListener { // factoryCategoryEntity.setBrand(brandName); // factoryCategoryEntity.setType(2); // BasicdataFactoryCategoryEntity categoryEntity = factoryCategoryClient.findEntityByBrandAndMaterielName(factoryCategoryEntity); - // factoryCategoryEntity.setType(1); - // BasicdataFactoryCategoryEntity categoryEntity1 = factoryCategoryClient.findEntityByBrandAndMaterielName(factoryCategoryEntity); - // if (ObjectUtil.isNotEmpty(categoryEntity)) { - // qualityDeliverEntity.setCostCategoryId(categoryEntity.getCategoryId()); - // qualityDeliverEntity.setCostCategory(categoryEntity.getCategory()); - // } - // if (ObjectUtil.isNotEmpty(categoryEntity1)) { - // qualityDeliverEntity.setRevenueCategory(categoryEntity.getCategory()); - // qualityDeliverEntity.setRevenueCategoryId(categoryEntity1.getCategoryId()); - // } - // TODO 从入库单上查询入库时间 + // factoryCategoryEntity.setType(1); + // BasicdataFactoryCategoryEntity categoryEntity1 = factoryCategoryClient.findEntityByBrandAndMaterielName(factoryCategoryEntity); + // if (ObjectUtil.isNotEmpty(categoryEntity)) { + // qualityDeliverEntity.setCostCategoryId(categoryEntity.getCategoryId()); + // qualityDeliverEntity.setCostCategory(categoryEntity.getCategory()); + // } + // if (ObjectUtil.isNotEmpty(categoryEntity1)) { + // qualityDeliverEntity.setRevenueCategory(categoryEntity.getCategory()); + // qualityDeliverEntity.setRevenueCategoryId(categoryEntity1.getCategoryId()); + // } + // TODO 从入库单上查询入库时间 // } } @@ -324,17 +334,17 @@ public class QualityDeliverListener { // 暂存单查询结算品类 // TrunklineAdvanceDetailEntity advanceDetailEntity = advanceDetailClient.findEntityByOrderPackageCode(qualityDeliverEntity.getOrderPackageCode()); // if (ObjectUtil.isNotEmpty(advanceDetailEntity)) { - // qualityDeliverEntity.setCostCategoryId(advanceDetailEntity.getCostCategoryId()); - // qualityDeliverEntity.setCostCategory(advanceDetailEntity.getCostCategoryName()); - // qualityDeliverEntity.setRevenueCategoryId(advanceDetailEntity.getIncomeCategoryId()); - // qualityDeliverEntity.setRevenueCategory(advanceDetailEntity.getIncomeCategoryName()); + // qualityDeliverEntity.setCostCategoryId(advanceDetailEntity.getCostCategoryId()); + // qualityDeliverEntity.setCostCategory(advanceDetailEntity.getCostCategoryName()); + // qualityDeliverEntity.setRevenueCategoryId(advanceDetailEntity.getIncomeCategoryId()); + // qualityDeliverEntity.setRevenueCategory(advanceDetailEntity.getIncomeCategoryName()); // } // 构建订单相关信息 buildOrderInfo(qualityDeliverEntity, qualityDeliverEntity.getWarehouseId(), qualityDeliverEntity.getOrderCode()); } private void buildOrderInfo(QualityDeliverEntity qualityDeliverEntity, Long warehouseId, String orderCode) { - DistributionStockArticleEntity stockArticleEntity = stockArticleService.findStockArticleByOrderCodeAndWarehouseId(orderCode, warehouseId); + DistributionStockArticleEntity stockArticleEntity = getDistributionStockArticleEntity(warehouseId, orderCode); if (ObjectUtil.isNotEmpty(stockArticleEntity)) { // 客户信息 qualityDeliverEntity.setCustomName(stockArticleEntity.getCustomerName()); @@ -356,9 +366,23 @@ public class QualityDeliverListener { } } + private DistributionStockArticleEntity getDistributionStockArticleEntity(Long warehouseId, String orderCode) { + String key = "report:qualityDeliver:stockArticle:" + warehouseId + "_" + orderCode; + String obj = redisCache.get(key); + if (StrUtil.isNotEmpty(obj)) { + return JSONUtil.toBean(obj, DistributionStockArticleEntity.class); + } + DistributionStockArticleEntity stockArticleEntity = stockArticleService.findStockArticleByOrderCodeAndWarehouseId(orderCode, warehouseId); + if (ObjectUtil.isNotEmpty(stockArticleEntity)) { + redisCache.setEx(key, JSONUtil.toJsonStr(stockArticleEntity), 60 * 60L + RandomUtil.randomInt(600)); + return stockArticleEntity; + } + return null; + } + private void buildWaybillInfo(QualityDeliverEntity qualityDeliverEntity, String waybillNumber) { if (StrUtil.isNotEmpty(waybillNumber)) { - WarehouseWaybillEntity byWaybillNo = warehouseWaybillClient.findByWaybillNo(waybillNumber); + WarehouseWaybillEntity byWaybillNo = getWarehouseWaybillEntity(waybillNumber); if (ObjectUtil.isNotEmpty(byWaybillNo)) { // 运单发货信息 qualityDeliverEntity.setShipperUnitId(byWaybillNo.getShipperId()); @@ -380,14 +404,41 @@ public class QualityDeliverListener { } } + private WarehouseWaybillEntity getWarehouseWaybillEntity(String waybillNumber) { + String key = "report:qualityDeliver:waybill:" + waybillNumber; + String obj = redisCache.get(key); + if (StrUtil.isNotEmpty(obj)) { + return JSONUtil.toBean(obj, WarehouseWaybillEntity.class); + } + WarehouseWaybillEntity byWaybillNo = warehouseWaybillClient.findByWaybillNo(waybillNumber); + if (ObjectUtil.isNotEmpty(byWaybillNo)) { + redisCache.setEx(key, JSONUtil.toJsonStr(byWaybillNo), 60 * 60L + RandomUtil.randomInt(600)); + return byWaybillNo; + } + return null; + } + private void warehouseInfo(QualityDeliverEntity qualityDeliverEntity) { - List warehouseEntities = warehouseClient.findWarehousesByIds(Arrays.asList(qualityDeliverEntity.getWarehouseId())); - if (CollUtil.isNotEmpty(warehouseEntities)) { - BasicdataWarehouseEntity warehouseEntity = warehouseEntities.get(0); + BasicdataWarehouseEntity warehouseEntity = getBasicdataWarehouseEntities(qualityDeliverEntity.getWarehouseId()); + if (ObjectUtil.isNotEmpty(warehouseEntity)) { // 事业线 qualityDeliverEntity.setBusinessUnit(warehouseEntity.getBusinessLine()); qualityDeliverEntity.setWarehousePosition(StrUtil.concat(true, Convert.toStr(warehouseEntity.getLongitude()), ",", Convert.toStr(warehouseEntity.getLatitude()))); } } + public BasicdataWarehouseEntity getBasicdataWarehouseEntities(Long warehouseId) { + String key = "report:qualityDeliver:warehouse:" + warehouseId; + String obj = redisCache.get(key); + if (StrUtil.isNotEmpty(obj)) { + return JSONUtil.toBean(obj, BasicdataWarehouseEntity.class); + } + List warehouseEntities = warehouseClient.findWarehousesByIds(Arrays.asList(warehouseId)); + if (CollUtil.isNotEmpty(warehouseEntities)) { + redisCache.setEx(key, JSONUtil.toJsonStr(warehouseEntities.get(0)), 60 * 60L + RandomUtil.randomInt(600)); + return warehouseEntities.get(0); + } + return null; + } + }