From ff31a324f8db4650b4ede03c73cf788d6b3366ee Mon Sep 17 00:00:00 2001 From: zhenghaoyu Date: Mon, 14 Oct 2024 10:25:15 +0800 Subject: [PATCH 1/5] =?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/5] =?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/5] =?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/5] =?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; + } + } From 248e3dea19c68eeb534278e996530d9436849d51 Mon Sep 17 00:00:00 2001 From: PigBaoBei <2739175034@qq.com> Date: Mon, 14 Oct 2024 18:23:04 +0800 Subject: [PATCH 5/5] =?UTF-8?q?=E5=A2=9E=E5=8A=A0=E5=85=A5=E5=BA=93?= =?UTF-8?q?=E9=85=8D=E7=BD=AE=E3=80=81=E4=BF=AE=E6=94=B9=E5=9C=A8=E5=BA=93?= =?UTF-8?q?=E8=AE=A2=E5=8D=95=E5=AF=BC=E5=87=BA?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../BasicdataGoodsAllocationEntity.java | 5 ++ .../IBasicdataGoodsAllocationClient.java | 33 +++++++++++ .../entity/WarehouseConfigEntity.java | 12 ++++ .../IWarehouseGoodsAllocationClient.java | 1 + .../BasicdataGoodsAllocationController.java | 10 ++++ .../feign/BasicdataGoodsAllocationClient.java | 28 +++++++++ .../mapper/BasicdataGoodsAllocationMapper.xml | 1 + .../IBasicdataGoodsAllocationService.java | 21 +++++++ .../BasicdataGoodsAllocationServiceImpl.java | 58 +++++++++++++++++++ .../mapper/DistributionStockArticleMapper.xml | 8 +-- .../mapper/DistrilbutionBillLadingMapper.xml | 8 ++- .../controller/WarehouseConfigController.java | 4 +- .../feign/WarehouseGoodsAllocationClient.java | 1 + .../service/IWarehouseConfigService.java | 7 +++ .../impl/WarehouseConfigServiceImpl.java | 39 +++++++++++++ .../WarehouseWarehousingEntryServiceImpl.java | 52 ++++++++++++----- 16 files changed, 267 insertions(+), 21 deletions(-) diff --git a/blade-service-api/logpm-basicdata-api/src/main/java/com/logpm/basicdata/entity/BasicdataGoodsAllocationEntity.java b/blade-service-api/logpm-basicdata-api/src/main/java/com/logpm/basicdata/entity/BasicdataGoodsAllocationEntity.java index e6d5144d8..efadf3408 100644 --- a/blade-service-api/logpm-basicdata-api/src/main/java/com/logpm/basicdata/entity/BasicdataGoodsAllocationEntity.java +++ b/blade-service-api/logpm-basicdata-api/src/main/java/com/logpm/basicdata/entity/BasicdataGoodsAllocationEntity.java @@ -129,6 +129,11 @@ public class BasicdataGoodsAllocationEntity extends TenantEntity { */ @ApiModelProperty(value = "旧库位码") private String oldQrCode; + /** + * 旧库位码 + */ + @ApiModelProperty(value = "旧库位码") + private Integer isDefault; diff --git a/blade-service-api/logpm-basicdata-api/src/main/java/com/logpm/basicdata/feign/IBasicdataGoodsAllocationClient.java b/blade-service-api/logpm-basicdata-api/src/main/java/com/logpm/basicdata/feign/IBasicdataGoodsAllocationClient.java index a92bc2e66..543d80a81 100644 --- a/blade-service-api/logpm-basicdata-api/src/main/java/com/logpm/basicdata/feign/IBasicdataGoodsAllocationClient.java +++ b/blade-service-api/logpm-basicdata-api/src/main/java/com/logpm/basicdata/feign/IBasicdataGoodsAllocationClient.java @@ -75,4 +75,37 @@ public interface IBasicdataGoodsAllocationClient { @PostMapping(API_PREFIX+"/updateListAllocationStatus") void updateListAllocationStatus(@RequestParam List updateAllocationIds, @RequestParam String allocationStatus); + + /** + * 查询默认库位 + * @param warehouseId + * @return + */ + @GetMapping(API_PREFIX+"/findDefaultGoodsAllocation") + BasicdataGoodsAllocationEntity findDefaultGoodsAllocation(@RequestParam Long warehouseId); + + /** + * 通过QRCode查询库位 + * @param warehouseId + * @param defaultAllocation + * @return + */ + @GetMapping(API_PREFIX+"/findEntityByQrCode") + BasicdataGoodsAllocationEntity findEntityByQrCode(@RequestParam Long warehouseId,@RequestParam String defaultAllocation); + + /** + * 开启默认库位 + * @param id + * @return + */ + @GetMapping(API_PREFIX+"/openDefaultAllocation") + boolean openDefaultAllocation(@RequestParam Long id); + + /** + * 关闭默认库位 + * @param warehouseId + * @return + */ + @GetMapping(API_PREFIX+"/closeDefaultAllocation") + boolean closeDefaultAllocation(@RequestParam Long id); } diff --git a/blade-service-api/logpm-warehouse-api/src/main/java/com/logpm/warehouse/entity/WarehouseConfigEntity.java b/blade-service-api/logpm-warehouse-api/src/main/java/com/logpm/warehouse/entity/WarehouseConfigEntity.java index e4363194b..869af202d 100644 --- a/blade-service-api/logpm-warehouse-api/src/main/java/com/logpm/warehouse/entity/WarehouseConfigEntity.java +++ b/blade-service-api/logpm-warehouse-api/src/main/java/com/logpm/warehouse/entity/WarehouseConfigEntity.java @@ -33,6 +33,18 @@ public class WarehouseConfigEntity extends TenantEntity { @ApiModelProperty(value = "是否自动释放") private Integer isAutoRelease; + /** + * 库存品是否自动上架 + */ + @ApiModelProperty(value = "库存品是否自动上架") + private Integer isAutoWarehouse; + + /** + * 默认库位 + */ + @ApiModelProperty(value = "默认库位") + private String defaultAllocation; + /** * 预留1 */ diff --git a/blade-service-api/logpm-warehouse-api/src/main/java/com/logpm/warehouse/feign/IWarehouseGoodsAllocationClient.java b/blade-service-api/logpm-warehouse-api/src/main/java/com/logpm/warehouse/feign/IWarehouseGoodsAllocationClient.java index 84da5f512..4ff39bf5f 100644 --- a/blade-service-api/logpm-warehouse-api/src/main/java/com/logpm/warehouse/feign/IWarehouseGoodsAllocationClient.java +++ b/blade-service-api/logpm-warehouse-api/src/main/java/com/logpm/warehouse/feign/IWarehouseGoodsAllocationClient.java @@ -64,4 +64,5 @@ public interface IWarehouseGoodsAllocationClient { @GetMapping(TOP+ "/findByAllocationQrCode") WarehouseGoodsAllocationEntity findByAllocationQrCode(@RequestParam String positions); + } diff --git a/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/controller/BasicdataGoodsAllocationController.java b/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/controller/BasicdataGoodsAllocationController.java index 2025b8020..d78f74a9d 100644 --- a/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/controller/BasicdataGoodsAllocationController.java +++ b/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/controller/BasicdataGoodsAllocationController.java @@ -126,6 +126,16 @@ public class BasicdataGoodsAllocationController extends BladeController { return R.status(basicdataGoodsAllocationService.updateGoodsAllocation(basicdataGoodsAllocationDto)); } + /** + * 货位 修改 + */ + @PostMapping("/updateDefault") + @ApiOperationSupport(order = 5) + @ApiOperation(value = "修改", notes = "传入BasicdataGoodsAllocation") + public R updateDefault(@Valid @RequestBody BasicdataGoodsAllocationDTO basicdataGoodsAllocationDto) { + return basicdataGoodsAllocationService.updateDefaultGoodsAllocation(basicdataGoodsAllocationDto); + } + /** * 货位 新增或修改 */ diff --git a/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/feign/BasicdataGoodsAllocationClient.java b/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/feign/BasicdataGoodsAllocationClient.java index 34c2b95c8..0b8ef3071 100644 --- a/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/feign/BasicdataGoodsAllocationClient.java +++ b/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/feign/BasicdataGoodsAllocationClient.java @@ -19,9 +19,11 @@ package com.logpm.basicdata.feign; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; +import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.logpm.basicdata.entity.BasicdataGoodsAllocationEntity; import com.logpm.basicdata.service.IBasicdataGoodsAllocationService; import lombok.AllArgsConstructor; +import org.springblade.common.constant.common.IsOrNoConstant; import org.springblade.core.mp.support.BladePage; import org.springblade.core.mp.support.Condition; import org.springblade.core.mp.support.Query; @@ -122,4 +124,30 @@ public class BasicdataGoodsAllocationClient implements IBasicdataGoodsAllocation BasicdataGoodsAllocationService.update(updateWrapper); } + @Override + public BasicdataGoodsAllocationEntity findDefaultGoodsAllocation(Long warehouseId) { + return BasicdataGoodsAllocationService.getOne(Wrappers.query().lambda() + .eq(BasicdataGoodsAllocationEntity::getWarehouseId,warehouseId) + .eq(BasicdataGoodsAllocationEntity::getIsDefault, Integer.parseInt(IsOrNoConstant.yes.getValue())) + ); + } + + @Override + public BasicdataGoodsAllocationEntity findEntityByQrCode(Long warehouseId, String defaultAllocation) { + return BasicdataGoodsAllocationService.getOne(Wrappers.query().lambda() + .eq(BasicdataGoodsAllocationEntity::getWarehouseId,warehouseId) + .eq(BasicdataGoodsAllocationEntity::getQrCode, defaultAllocation) + ); + } + + @Override + public boolean openDefaultAllocation(Long id) { + return BasicdataGoodsAllocationService.openDefaultAllocation(id); + } + + @Override + public boolean closeDefaultAllocation(Long id) { + return BasicdataGoodsAllocationService.closeDefaultAllocation(id); + } + } diff --git a/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataGoodsAllocationMapper.xml b/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataGoodsAllocationMapper.xml index a710bdf78..ffcfd7a48 100644 --- a/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataGoodsAllocationMapper.xml +++ b/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/mapper/BasicdataGoodsAllocationMapper.xml @@ -99,6 +99,7 @@ goods_area.headline AS goodsAreaName, warehouse.name AS warehouseName, goods_area.area_type AS area_type, + goods_allocation.is_default, CASE goods_area.area_type WHEN 1 THEN '备货库位' WHEN 2 THEN '存储库位' diff --git a/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/IBasicdataGoodsAllocationService.java b/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/IBasicdataGoodsAllocationService.java index a9fc0b76c..840393dcc 100644 --- a/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/IBasicdataGoodsAllocationService.java +++ b/blade-service/logpm-basicdata/src/main/java/com/logpm/basicdata/service/IBasicdataGoodsAllocationService.java @@ -131,4 +131,25 @@ public interface IBasicdataGoodsAllocationService extends BaseService selectBasicdataGoodsAllocationPage(IPage page, BasicdataGoodsAllocationVO BasicdataGoodsAllocation) { @@ -372,4 +377,57 @@ public class BasicdataGoodsAllocationServiceImpl extends BaseServiceImplupdate().lambda() + .eq(BasicdataGoodsAllocationEntity::getWarehouseId,myCurrentWarehouse.getId()) + .ne(BasicdataGoodsAllocationEntity::getId,goodsAllocationDtoId) + .set(BasicdataGoodsAllocationEntity::getIsDefault,Integer.parseInt(IsOrNoConstant.no.getValue())) + ); + return R.status(this.updateById(basicdataGoodsAllocationEntity)); + } + + @Override + public boolean openDefaultAllocation(Long id) { + BasicdataGoodsAllocationDTO basicdataGoodsAllocationDTO = new BasicdataGoodsAllocationDTO(); + basicdataGoodsAllocationDTO.setId(id); + basicdataGoodsAllocationDTO.setIsDefault(Integer.parseInt(IsOrNoConstant.yes.getValue())); + R r = this.updateDefaultGoodsAllocation(basicdataGoodsAllocationDTO); + return r.isSuccess(); + } + + @Override + public boolean closeDefaultAllocation(Long id) { + BasicdataGoodsAllocationDTO basicdataGoodsAllocationDTO = new BasicdataGoodsAllocationDTO(); + basicdataGoodsAllocationDTO.setId(id); + basicdataGoodsAllocationDTO.setIsDefault(Integer.parseInt(IsOrNoConstant.no.getValue())); + R r = this.updateDefaultGoodsAllocation(basicdataGoodsAllocationDTO); + return r.isSuccess(); + } } diff --git a/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/mapper/DistributionStockArticleMapper.xml b/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/mapper/DistributionStockArticleMapper.xml index 505044a10..901a42d84 100644 --- a/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/mapper/DistributionStockArticleMapper.xml +++ b/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/mapper/DistributionStockArticleMapper.xml @@ -987,11 +987,11 @@ #{wIitem} - and ldpl.waybill_number = - #{param.waybillNumber} + and ldpl.waybill_number LIKE CONCAT('%',#{param.waybillNumber},'%') + - and ldsa.order_code = #{param.orderCode} - and ldsa.mall_name = #{param.mallName} + and ldsa.order_code LIKE CONCAT('%',#{param.orderCode},'%') + and ldsa.mall_name LIKE CONCAT('%',#{param.mallName},'%') and ldsa.type_service = #{param.typeService} diff --git a/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/mapper/DistrilbutionBillLadingMapper.xml b/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/mapper/DistrilbutionBillLadingMapper.xml index 9027811e6..c5e7bab6f 100644 --- a/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/mapper/DistrilbutionBillLadingMapper.xml +++ b/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/mapper/DistrilbutionBillLadingMapper.xml @@ -470,10 +470,12 @@ lad.is_deleted = 0 and lad.warehouse_id = #{param.warehouseId} - and lad.pick_up_time between - #{param.pickUpTimeStart} and #{param.pickUpTimeEnd} + + AND DATE_FORMAT(lad.pick_up_time,'%y%m%d') between + DATE_FORMAT(#{param.pickUpTimeStart},'%y%m%d') and DATE_FORMAT(#{param.pickUpTimeEnd},'%y%m%d') - and lad.conditions in (10,20) + + and lad.conditions in (10,20) diff --git a/blade-service/logpm-warehouse/src/main/java/com/logpm/warehouse/controller/WarehouseConfigController.java b/blade-service/logpm-warehouse/src/main/java/com/logpm/warehouse/controller/WarehouseConfigController.java index 3d8788aa7..8973dc800 100644 --- a/blade-service/logpm-warehouse/src/main/java/com/logpm/warehouse/controller/WarehouseConfigController.java +++ b/blade-service/logpm-warehouse/src/main/java/com/logpm/warehouse/controller/WarehouseConfigController.java @@ -97,7 +97,9 @@ public class WarehouseConfigController extends BladeController { @ApiOperationSupport(order = 5) @ApiOperation(value = "修改", notes = "传入warehouseWaybill") public R update(@Valid @RequestBody WarehouseConfigEntity warehouseConfigEntity) { - return R.status(warehouseConfigService.updateById(warehouseConfigEntity)); + + + return warehouseConfigService.updateWarehouseConfigEntity(warehouseConfigEntity); } } diff --git a/blade-service/logpm-warehouse/src/main/java/com/logpm/warehouse/feign/WarehouseGoodsAllocationClient.java b/blade-service/logpm-warehouse/src/main/java/com/logpm/warehouse/feign/WarehouseGoodsAllocationClient.java index d82ad97ee..aeff2b86b 100644 --- a/blade-service/logpm-warehouse/src/main/java/com/logpm/warehouse/feign/WarehouseGoodsAllocationClient.java +++ b/blade-service/logpm-warehouse/src/main/java/com/logpm/warehouse/feign/WarehouseGoodsAllocationClient.java @@ -78,4 +78,5 @@ public class WarehouseGoodsAllocationClient implements IWarehouseGoodsAllocation .eq(WarehouseGoodsAllocationEntity::getQrCode,positions) ).get(0); } + } diff --git a/blade-service/logpm-warehouse/src/main/java/com/logpm/warehouse/service/IWarehouseConfigService.java b/blade-service/logpm-warehouse/src/main/java/com/logpm/warehouse/service/IWarehouseConfigService.java index 602a6475d..62f93363b 100644 --- a/blade-service/logpm-warehouse/src/main/java/com/logpm/warehouse/service/IWarehouseConfigService.java +++ b/blade-service/logpm-warehouse/src/main/java/com/logpm/warehouse/service/IWarehouseConfigService.java @@ -3,8 +3,15 @@ package com.logpm.warehouse.service; import com.logpm.warehouse.entity.WarehouseConfigEntity; import com.logpm.warehouse.entity.WarehouseLog; import org.springblade.core.mp.base.BaseService; +import org.springblade.core.tool.api.R; public interface IWarehouseConfigService extends BaseService { + /** + * 修改仓库配置 + * @param warehouseConfigEntity + * @return + */ + R updateWarehouseConfigEntity(WarehouseConfigEntity warehouseConfigEntity); } diff --git a/blade-service/logpm-warehouse/src/main/java/com/logpm/warehouse/service/impl/WarehouseConfigServiceImpl.java b/blade-service/logpm-warehouse/src/main/java/com/logpm/warehouse/service/impl/WarehouseConfigServiceImpl.java index 3f2ec193b..9b469df22 100644 --- a/blade-service/logpm-warehouse/src/main/java/com/logpm/warehouse/service/impl/WarehouseConfigServiceImpl.java +++ b/blade-service/logpm-warehouse/src/main/java/com/logpm/warehouse/service/impl/WarehouseConfigServiceImpl.java @@ -1,16 +1,24 @@ package com.logpm.warehouse.service.impl; +import com.logpm.basicdata.entity.BasicdataGoodsAllocationEntity; +import com.logpm.basicdata.feign.IBasicdataGoodsAllocationClient; import com.logpm.warehouse.entity.WarehouseConfigEntity; +import com.logpm.warehouse.entity.WarehouseGoodsAllocationEntity; import com.logpm.warehouse.entity.WarehouseLog; +import com.logpm.warehouse.feign.IWarehouseGoodsAllocationClient; import com.logpm.warehouse.mapper.WarehouseConfigMapper; import com.logpm.warehouse.mapper.WarehouseLogMapper; import com.logpm.warehouse.service.IWarehouseConfigService; import com.logpm.warehouse.service.IWarehouseLogService; import lombok.AllArgsConstructor; import lombok.extern.slf4j.Slf4j; +import org.springblade.common.constant.common.IsOrNoConstant; import org.springblade.core.mp.base.BaseServiceImpl; +import org.springblade.core.tool.api.R; import org.springframework.stereotype.Service; +import java.util.Objects; + @Slf4j @AllArgsConstructor @Service @@ -18,5 +26,36 @@ public class WarehouseConfigServiceImpl extends BaseServiceImpl> distriType = dictBizClient.getList("distribution_type"); if (ObjectUtils.isNotNull(distriType)) { List data1 = distriType.getData(); -// data1.forEach( a ->{ -// if(o.getServiceType().equals(a.getDictValue())){ -// entryEntity.setServiceType(a.getDictKey()); //仓库名称 -// } -// }); DictBiz dictBiz = data1.stream().filter(da -> { return o.getServiceType().equals(da.getDictValue()); }).findAny().get(); @@ -544,6 +538,28 @@ public class WarehouseWarehousingEntryServiceImpl extends BaseServiceImpl>>>>>>>>>>+++++"+k+v); WarehouseWarehousingEntryEntity entryEntity = JSON.parseObject(k, WarehouseWarehousingEntryEntity.class); // WarehouseWarehousingEntryEntity entryEntity = JSONObject.parseObject(JSONObject.toJSONString(k), WarehouseWarehousingEntryEntity.class); + + Integer isAutoWarehouse; + if (!Objects.isNull(entryEntity.getWarehouseId())){ + //查询是否开启自动上架配置 + WarehouseConfigEntity warehouseConfig = warehouseConfigClient.getWarehouseConfig(entryEntity.getWarehouseId()); + if (!Objects.isNull(warehouseConfig)){ + isAutoWarehouse = warehouseConfig.getIsAutoWarehouse() != null ? warehouseConfig.getIsAutoWarehouse() : 0; + } else { + isAutoWarehouse = 0; + } + } else { + isAutoWarehouse = 0; + } + if (Integer.parseInt(IsOrNoConstant.yes.getValue()) == isAutoWarehouse){ + //查询默认备货库位 + BasicdataGoodsAllocationEntity defaultGoodsAllocation = basicdataGoodsAllocationClient.findDefaultGoodsAllocation(entryEntity.getWarehouseId()); + if (!Objects.isNull(defaultGoodsAllocation)){ + if (Objects.isNull(entryEntity.getPositions())){ + entryEntity.setPositions(defaultGoodsAllocation.getQrCode()); + } + } + } this.save(entryEntity); List detailEntityList = new ArrayList<>(); v.forEach(i -> { @@ -580,6 +596,16 @@ public class WarehouseWarehousingEntryServiceImpl extends BaseServiceImpl