From 5e38c75bc9c609d5e41bf817756ef8ed7a0f4851 Mon Sep 17 00:00:00 2001
From: lsh <lsh@163.com>
Date: 星期四, 21 八月 2025 15:28:27 +0800
Subject: [PATCH] *
---
src/main/java/com/zy/asrs/task/handler/BareBoardHandler.java | 61 ++++++++++++++++++++++++++----
1 files changed, 52 insertions(+), 9 deletions(-)
diff --git a/src/main/java/com/zy/asrs/task/handler/BareBoardHandler.java b/src/main/java/com/zy/asrs/task/handler/BareBoardHandler.java
index e73f080..af19382 100644
--- a/src/main/java/com/zy/asrs/task/handler/BareBoardHandler.java
+++ b/src/main/java/com/zy/asrs/task/handler/BareBoardHandler.java
@@ -21,9 +21,7 @@
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
-import java.util.ArrayList;
-import java.util.Date;
-import java.util.List;
+import java.util.*;
/**
* Created by Monkey D. Luffy on 2023.07.24
@@ -61,18 +59,38 @@
// 鑾峰彇宸ヤ綔鍙�
int workNo = commonService.getWorkNo(WorkNoType.PAKOUT.type);
ArrayList<Integer> crns =new ArrayList<>();
- List<BasCrnp> basCrnps = basCrnpService.selectList(new EntityWrapper<BasCrnp>().eq("crn_sts", 3).eq("out_enable", "Y").eq("wrk_no", 0));
- for (BasCrnp basCrnp : basCrnps){
- crns.add(basCrnp.getCrnNo());
- }
+
crns.add(1);
crns.add(2);
crns.add(3);
crns.add(4);
crns.add(5);
crns.add(6);
- boolean sign = true;
+
+ ArrayList<Integer> crnList =new ArrayList<>();
+ int[] crnCount = new int[6];
for (Integer crnNo : crns){
+ int crnCountD = locMastService.selectCount(new EntityWrapper<LocMast>().eq("loc_sts", "D").eq("crn_no", crnNo));
+ crnCount[crnNo-1] = crnCountD;
+ }
+ int[] sortedCrnNos = getSortedCrnNos(crnCount);
+ for (int crnNo : sortedCrnNos){
+ crnList.add(crnNo);
+ }
+ crnList.add(6);
+ crnList.add(1);
+ crnList.add(4);
+ crnList.add(3);
+ crnList.add(5);
+ crnList.add(2);
+
+// List<BasCrnp> basCrnps = basCrnpService.selectList(new EntityWrapper<BasCrnp>().eq("crn_sts", 3).eq("out_enable", "Y").eq("wrk_no", 0));
+// for (BasCrnp basCrnp : basCrnps){
+// crns.add(basCrnp.getCrnNo());
+// }
+
+ boolean sign = true;
+ for (Integer crnNo : crnList){
BasCrnp basCrnp = basCrnpService.selectById(crnNo);
if (basCrnp.getCrnSts()!=3 || !basCrnp.getOutEnable().equals("Y")){
continue;
@@ -135,7 +153,7 @@
wrkMast.setIoTime(now);
wrkMast.setWrkSts(11L); // 宸ヤ綔鐘舵�侊細11.鐢熸垚鍑哄簱ID
wrkMast.setIoType(110); // 鍏ュ嚭搴撶姸鎬侊細 110.绌烘澘鍑哄簱
- wrkMast.setIoPri(10D);
+ wrkMast.setIoPri(99999999D);
wrkMast.setSourceStaNo(sourceStaNo); // 婧愮珯
wrkMast.setStaNo(staNo); // 鐩爣绔�
wrkMast.setCrnNo(locMast.getCrnNo());
@@ -177,4 +195,29 @@
}
return SUCCESS;
}
+
+ /**
+ * 鏍规嵁鍫嗗灈鏈烘暟閲忎粠澶у埌灏忔帓搴忥紝杩斿洖鎺掑簭鍚庣殑鍫嗗灈鏈哄彿
+ *
+ * @param crnCount 鍫嗗灈鏈烘暟閲忔暟缁勶紝绱㈠紩琛ㄧず鍫嗗灈鏈哄彿鍑� 1
+ * @return 鎺掑簭鍚庣殑鍫嗗灈鏈哄彿鏁扮粍
+ */
+ public static int[] getSortedCrnNos(int[] crnCount) {
+ // 鍒涘缓涓�涓垪琛紝瀛樺偍鍫嗗灈鏈哄彿鍜屽搴旂殑鍊�
+ List<Map.Entry<Integer, Integer>> list = new ArrayList<>();
+ for (int i = 0; i < crnCount.length; i++) {
+ list.add(new AbstractMap.SimpleEntry<>(i + 1, crnCount[i])); // 鍫嗗灈鏈哄彿浠� 1 寮�濮�
+ }
+
+ // 鏍规嵁鍊间粠澶у埌灏忔帓搴�
+ list.sort((entry1, entry2) -> entry2.getValue().compareTo(entry1.getValue()));
+
+ // 鎻愬彇鎺掑簭鍚庣殑鍫嗗灈鏈哄彿
+ int[] sortedCrnNos = new int[list.size()];
+ for (int i = 0; i < list.size(); i++) {
+ sortedCrnNos[i] = list.get(i).getKey();
+ }
+
+ return sortedCrnNos;
+ }
}
--
Gitblit v1.9.1