From 4c5e705c9ac10827254900305b7b915191005db4 Mon Sep 17 00:00:00 2001
From: cl <1442464845@qq.com>
Date: 星期二, 21 四月 2026 15:25:16 +0800
Subject: [PATCH] 版改板

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/utils/LocManageUtil.java |   63 +++++++++++++------------------
 1 files changed, 27 insertions(+), 36 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/utils/LocManageUtil.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/utils/LocManageUtil.java
index 5e73f65..69493ea 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/utils/LocManageUtil.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/utils/LocManageUtil.java
@@ -96,14 +96,12 @@
     public static List<LocItem> getEfficiencyFirstItemList(String matnrCode, String splrBatch, Double anfme) {
         LambdaQueryWrapper<LocItem> locItemQueryWrapper = new LambdaQueryWrapper<>();
         locItemQueryWrapper.eq(LocItem::getMatnrCode, matnrCode);
-        locItemQueryWrapper.eq(StringUtils.isNotBlank(splrBatch), LocItem::getBatch, splrBatch);
-        String applySql = String.format(
-                "EXISTS (SELECT 1 FROM man_loc ml " +
-                        "WHERE ml.use_status = '%s'" +
-                        "AND ml.id = man_loc_item.loc_id " +
-                        ")",
-                LocStsType.LOC_STS_TYPE_F.type
-        );
+        // 鏈夋壒娆℃椂锛氬尮閰嶅簱浣嶆壒娆�=璁㈠崟鎵规 鎴� 搴撲綅鎵规涓虹┖锛堟棤鎵规搴撳瓨鍙弬涓庡垎閰嶏紝閬垮厤璇垽搴撳瓨涓嶈冻锛�
+        if (StringUtils.isNotBlank(splrBatch)) {
+            locItemQueryWrapper.and(w -> w.eq(LocItem::getBatch, splrBatch).or().isNull(LocItem::getBatch));
+        }
+        // 鍚� F.鍦ㄥ簱 涓� R.鍑哄簱棰勭害锛堟嫞鏂欏嚭搴撴湭纭鍓嶅彲鍐嶄笅鍙戯紝浣跨敤鍓╀綑鍙敤锛� 鈥淟ocStsType.LOC_STS_TYPE_R.type鐢ㄤ簬鍑哄簱鎷f枡杩囩▼涓拷鍔犵浉鍚岀墿鏂欏嚭搴撳崟鈥�
+        String applySql = "EXISTS (SELECT 1 FROM man_loc ml WHERE ml.use_status IN ('" + LocStsType.LOC_STS_TYPE_F.type + "','" + LocStsType.LOC_STS_TYPE_R.type + "') AND ml.id = man_loc_item.loc_id AND ml.deleted = 0)";
         locItemQueryWrapper.apply(applySql);
         LocItemService locItemService = SpringUtils.getBean(LocItemService.class);
         List<LocItem> locItems = locItemService.list(locItemQueryWrapper);
@@ -127,21 +125,19 @@
     public static List<LocItem> getFirstInFirstOutItemList(String matnrCode, String splrBatch, Double anfme) {
         LambdaQueryWrapper<LocItem> locItemQueryWrapper = new LambdaQueryWrapper<>();
         locItemQueryWrapper.eq(LocItem::getMatnrCode, matnrCode);
-        locItemQueryWrapper.eq(StringUtils.isNotEmpty(splrBatch), LocItem::getBatch, splrBatch);
+        // 鏈夋壒娆℃椂锛氬尮閰嶅簱浣嶆壒娆�=璁㈠崟鎵规 鎴� 搴撲綅鎵规涓虹┖锛堟棤鎵规搴撳瓨鍙弬涓庡垎閰嶏紝閬垮厤璇垽搴撳瓨涓嶈冻锛�
+        if (StringUtils.isNotBlank(splrBatch)) {
+            locItemQueryWrapper.and(w -> w.eq(LocItem::getBatch, splrBatch).or().isNull(LocItem::getBatch));
+        }
         //濡傛灉鎵规涓嶄负绌猴紝鎸夋壒娆″厛鍚庡嚭搴�
         if (StringUtils.isNotBlank(splrBatch)) {
             locItemQueryWrapper.orderByAsc(LocItem::getBatch);
         } else {
             locItemQueryWrapper.orderByAsc(LocItem::getCreateTime);
         }
-        String applySql = String.format(
-                "EXISTS (SELECT 1 FROM man_loc ml " +
-                        "WHERE ml.use_status = '%s'" +
-                        "AND ml.id = man_loc_item.loc_id " +
-                        ")",
-                LocStsType.LOC_STS_TYPE_F.type
-        );
-        locItemQueryWrapper.apply(applySql);
+        // 鍚� F.鍦ㄥ簱 涓� R.鍑哄簱棰勭害锛堟嫞鏂欏嚭搴撴湭纭鍓嶅彲鍐嶄笅鍙戯紝浣跨敤鍓╀綑鍙敤锛� 鈥淟ocStsType.LOC_STS_TYPE_R.type鐢ㄤ簬鍑哄簱鎷f枡杩囩▼涓拷鍔犵浉鍚岀墿鏂欏嚭搴撳崟鈥�
+        String applySqlR = "EXISTS (SELECT 1 FROM man_loc ml WHERE ml.use_status IN ('" + LocStsType.LOC_STS_TYPE_F.type + "','" + LocStsType.LOC_STS_TYPE_R.type + "') AND ml.id = man_loc_item.loc_id AND ml.deleted = 0)";
+        locItemQueryWrapper.apply(applySqlR);
         LocItemService locItemService = SpringUtils.getBean(LocItemService.class);
         List<LocItem> locItems = locItemService.list(locItemQueryWrapper);
         return locItems;
@@ -160,8 +156,6 @@
         DeviceSiteService deviceSiteService = SpringUtils.getBean(DeviceSiteService.class);
 
         List<OrderOutItemDto> list = new ArrayList<>();
-        //涓嶈绔欑偣閲嶅浣跨敤闂
-        List<BasStation> stations = new ArrayList<>();
         List<ExistDto> existDtos = new ArrayList<>();
         Set<Loc> locs = new HashSet<>();
         for (WaveToLocParams item : params) {
@@ -211,27 +205,24 @@
                                     maps.add(staListDto);
                                 }
                                 orderOutItemDto.setStaNos(maps);
-                                //鑾峰彇婊¤冻鏉′欢绔欑偣
+                                // 鎸夊彲鍑鸿鍒欓�夋嫨绔欑偣
                                 Set<String> stationSet = deviceSites.stream().map(DeviceSite::getSite).collect(Collectors.toSet());
-                                String sType = "H";
-                                //鑾峰彇楂樹綆绔欑偣绫诲瀷
-                                if (startsWithTwoChars(loc.getBarcode(), "31")) {
-                                    sType = "L";
-                                }
-                                //宸蹭娇鐢ㄧ珯鐐�
-                                Set<String> stas = stations.stream().map(BasStation::getStationName).collect(Collectors.toSet());
                                 BasStationService basStationService = SpringUtils.getBean(BasStationService.class);
-                                BasStation basStation = basStationService.getOne(new LambdaQueryWrapper<BasStation>()
-                                        .eq(BasStation::getUseStatus, LocStsType.LOC_STS_TYPE_O.type)
+                                List<BasStation> candidateStations = basStationService.list(new LambdaQueryWrapper<BasStation>()
                                         .in(BasStation::getStationName, stationSet)
-//                                        .eq(BasStation::getSType, sType)
-                                        .notIn(!stas.isEmpty(), BasStation::getStationName, stas)
-                                        .last("LIMIT 1"));
-                                stations.add(basStation);
-
-                                if (Objects.isNull(basStation)) {
-                                    throw new CoolException("绔欓粸涓嶅瓨鍦紒锛�");
+                                        .eq(BasStation::getStatus, 1)
+                                        .eq(BasStation::getOutAble, 1));
+                                if (candidateStations.isEmpty()) {
+                                    throw new CoolException("鏃犲彲鍑虹珯鐐癸紝璇锋鏌ョ珯鐐圭姸鎬佹垨鑳藉嚭閰嶇疆锛侊紒");
                                 }
+                                candidateStations.sort((a, b) -> {
+                                    boolean a1001 = "1001".equals(a.getStationName());
+                                    boolean b1001 = "1001".equals(b.getStationName());
+                                    if (a1001 && !b1001) return -1;
+                                    if (!a1001 && b1001) return 1;
+                                    return 0;
+                                });
+                                BasStation basStation = candidateStations.get(0);
                                 orderOutItemDto.setSitesNo(basStation.getStationName());
                             }
                         }

--
Gitblit v1.9.1