From a44e66e91a00405d4651a9b9dd395c35708df5b9 Mon Sep 17 00:00:00 2001
From: zyx <zyx123456>
Date: 星期二, 16 七月 2024 15:21:44 +0800
Subject: [PATCH] 找库位逻辑bug修改

---
 zy-asrs-common/src/main/java/com/zy/asrs/common/wms/service/CommonService.java |   16 ++++++++++++++--
 1 files changed, 14 insertions(+), 2 deletions(-)

diff --git a/zy-asrs-common/src/main/java/com/zy/asrs/common/wms/service/CommonService.java b/zy-asrs-common/src/main/java/com/zy/asrs/common/wms/service/CommonService.java
index 37c6eb6..7a69542 100644
--- a/zy-asrs-common/src/main/java/com/zy/asrs/common/wms/service/CommonService.java
+++ b/zy-asrs-common/src/main/java/com/zy/asrs/common/wms/service/CommonService.java
@@ -46,6 +46,8 @@
     @Autowired
     private LocDirectionService locDirectionService;
 
+    private Long WHS_TYPE = 0L;//榛樿绔嬪簱
+
     /**
      * 鐢熸垚宸ヤ綔鍙�
      *
@@ -91,6 +93,11 @@
      */
     @Transactional
     public StartupDto getLocNo(Integer staDescId, Integer sourceStaNo, List<String> matnrs, String batch, Long hostId, LocTypeDto locTypeDto, int times) {
+        if (sourceStaNo==999){//骞冲簱鍐呯疆鍒ゆ柇绔欑偣锛堜复鏃惰В鍐虫柟妗堬級
+            WHS_TYPE = 1L;//骞冲簱
+        } else {
+            WHS_TYPE = 0L;//绔嬪簱
+        }
         // 鐩爣搴撲綅
         LocMast locMast = null;
 
@@ -150,7 +157,7 @@
                 continue;
             }
 
-            List<LocMast> locMasts = locMastService.queryFreeLocMast2(locTypeDto.getLocType1(), locRule.getRowBeg(), locRule.getRowEnd(), locRule.getBayBeg(), locRule.getBayEnd(), locRule.getLevBeg(), locRule.getLevEnd(), hostId);
+            List<LocMast> locMasts = locMastService.queryFreeLocMast2(locTypeDto.getLocType1(), locRule.getRowBeg(), locRule.getRowEnd(), locRule.getBayBeg(), locRule.getBayEnd(), locRule.getLevBeg(), locRule.getLevEnd(), hostId,WHS_TYPE);
             for (LocMast locMast0 : locMasts) {
                 //棰勭暀绌哄簱浣�
                 if (locMastService.checkEmptyCount(locMast0, 10, hostId)) {
@@ -237,12 +244,14 @@
                     .eq(LocMast::getLocSts, "D")
                     .eq(LocMast::getLocType1, locTypeDto.getLocType1())
                     .eq(LocMast::getCrnNo, staDesc.getDeviceNo())
+                    .eq(LocMast::getWhsType, WHS_TYPE)
                     .eq(LocMast::getHostId, hostId);
 
             LambdaQueryWrapper<LocMast> wrapper1 = new LambdaQueryWrapper<LocMast>()
                     .eq(LocMast::getLocSts, "O")
                     .eq(LocMast::getLocType1, locTypeDto.getLocType1())
                     .eq(LocMast::getCrnNo, staDesc.getDeviceNo())
+                    .eq(LocMast::getWhsType, WHS_TYPE)
                     .eq(LocMast::getHostId, hostId);
 
             //搴撲綅鎼滅储鑼冨洿
@@ -313,7 +322,10 @@
                 .eq(LocMast::getLocSts, "O")
                 .eq(LocMast::getHostId, hostId)
                 .in(LocMast::getRow1, curRow)
-                .orderByAsc(LocMast::getLev1);
+                .orderByAsc(LocMast::getLev1)
+                .orderByAsc(LocMast::getBay1);
+
+
         //搴撲綅鎼滅储鑼冨洿
         LocRangeDto locRangeDto = locTypeDto.getLocRangeDto();
         if (locRangeDto != null) {

--
Gitblit v1.9.1