From fc634e5b62b85396196e2dd8f51bfe5ba7337522 Mon Sep 17 00:00:00 2001
From: cl <1442464845@qq.com>
Date: 星期二, 21 四月 2026 15:02:14 +0800
Subject: [PATCH] 站点优化
---
rsf-server/src/main/java/com/vincent/rsf/server/manager/utils/LocManageUtil.java | 33 ++++++++++++++-------------------
1 files changed, 14 insertions(+), 19 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 6562998..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
@@ -156,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) {
@@ -207,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