From 03f63637e706283f1a95b7d0d6d631901ae359b2 Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期一, 21 七月 2025 13:24:00 +0800
Subject: [PATCH] 盘点单功能优化

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/CheckOrderSchedules.java |   26 +++++++++++++++++++-------
 1 files changed, 19 insertions(+), 7 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/CheckOrderSchedules.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/CheckOrderSchedules.java
index a1fb5ed..d201957 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/CheckOrderSchedules.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/schedules/CheckOrderSchedules.java
@@ -47,15 +47,27 @@
      * @description: 鑷姩鑾峰彇宸茬敓鎴愮洏鐐逛换鍔$殑鐩樼偣鍒楄〃
      * @version 1.0
      */
-    @Scheduled(cron = "0/5 * * * * ?")
+    @Scheduled(cron = "0/15 * * * * ?")
     @Transactional(rollbackFor = Exception.class)
     public void genReCheck() {
-        List<CheckDiffItem> list = checkDiffItemService.list(new LambdaQueryWrapper<CheckDiffItem>().select(CheckDiffItem::getTaskItemId));
+        List<Task> tasks = taskService.list(new LambdaQueryWrapper<Task>()
+                .select(Task::getId)
+                .eq(Task::getTaskType, TaskType.TASK_TYPE_CHECK_OUT.type));
+        if (tasks.isEmpty()) {
+            return;
+        }
+        List<CheckDiffItem> list = checkDiffItemService
+                .list(new LambdaQueryWrapper<CheckDiffItem>()
+                        .select(CheckDiffItem::getTaskItemId));
         if (list.isEmpty()) {
             return;
         }
+        Set<Long> taskIds = tasks.stream().map(Task::getId).collect(Collectors.toSet());
         List<Long> itemIds = list.stream().map(CheckDiffItem::getTaskItemId).collect(Collectors.toList());
-        List<TaskItem> taskItems = taskItemService.list(new LambdaQueryWrapper<TaskItem>().notIn(TaskItem::getId, itemIds));
+        List<TaskItem> taskItems = taskItemService
+                .list(new LambdaQueryWrapper<TaskItem>()
+                        .in(TaskItem::getTaskId, taskIds)
+                        .notIn(TaskItem::getId, itemIds));
         if (taskItems.isEmpty()) {
             return;
         }
@@ -64,7 +76,7 @@
         taskMps.keySet().forEach(orderId -> {
             WkOrder order = checkOrderService.getById(orderId);
             if (Objects.isNull(order)) {
-               throw new CoolException("鐩樼偣鍗曟嵁涓嶅瓨鍦紒锛�");
+                throw new CoolException("鐩樼偣鍗曟嵁涓嶅瓨鍦紒锛�");
             }
             CheckDiff checkDiff = checkDiffService.getOne(new LambdaQueryWrapper<CheckDiff>().eq(CheckDiff::getOrderId, orderId));
             if (Objects.isNull(checkDiff)) {
@@ -119,9 +131,9 @@
                 }
             });
 
-           if (!checkDiffItemService.saveBatch(diffItems)) {
-               throw new CoolException("鐩樼偣宸紓鍗曚繚瀛樺け璐ワ紒锛�");
-           }
+            if (!checkDiffItemService.saveBatch(diffItems)) {
+                throw new CoolException("鐩樼偣宸紓鍗曚繚瀛樺け璐ワ紒锛�");
+            }
         });
     }
 }

--
Gitblit v1.9.1