From 209878277a178ab91d48b523265e5ffb1b8cf7e6 Mon Sep 17 00:00:00 2001
From: chen.lin <1442464845@qq.com>
Date: 星期一, 09 三月 2026 16:18:21 +0800
Subject: [PATCH] 库位转移,优化查询速度

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/TaskServiceImpl.java |   36 +++++++++++++++++++++++++++++++++++-
 1 files changed, 35 insertions(+), 1 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/TaskServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/TaskServiceImpl.java
index 2249ac0..b9ea8c4 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/TaskServiceImpl.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/TaskServiceImpl.java
@@ -1132,7 +1132,39 @@
         if (!taskService.updateById(task)) {
             throw new CoolException("浠诲姟鐘舵�佷慨鏀瑰け璐ワ紒锛�");
         }
+        // 鐩樼偣鍐嶅叆搴撲换鍔$粨鏉燂細灏嗗叧鑱旂殑鐩樼偣宸紓鍗曠疆涓哄凡瀹℃牳
+        if (TaskType.TASK_TYPE_CHECK_IN.type.equals(task.getTaskType())) {
+            markCheckDiffApprovedWhenCheckInDone(task);
+        }
+    }
 
+    /**
+     * 鐩樼偣鍐嶅叆搴撳畬鎴愬悗锛屽皢鍏宠仈鐨勭洏鐐瑰樊寮傚崟缃负宸插鏍革紙鏈夊崟鎸� orderId锛屾棤鍗曟寜 鍑哄簱浠诲姟鍙� orderCode锛�
+     */
+    @Override
+    public void markCheckDiffApprovedWhenCheckInDone(Task checkInTask) {
+        List<TaskItem> items = taskItemService.list(new LambdaQueryWrapper<TaskItem>().eq(TaskItem::getTaskId, checkInTask.getId()).last("limit 1"));
+        Long orderId = items.isEmpty() ? null : items.get(0).getOrderId();
+        CheckDiff checkDiff = null;
+        if (orderId != null && !orderId.equals(0L)) {
+            checkDiff = checkDiffService.getOne(new LambdaQueryWrapper<CheckDiff>().eq(CheckDiff::getOrderId, orderId).last("limit 1"));
+        } else {
+            Task outTask = taskService.getOne(new LambdaQueryWrapper<Task>()
+                    .eq(Task::getBarcode, checkInTask.getBarcode())
+                    .eq(Task::getTaskType, TaskType.TASK_TYPE_CHECK_OUT.type)
+                    .last("limit 1"));
+            if (outTask != null) {
+                checkDiff = checkDiffService.getOne(new LambdaQueryWrapper<CheckDiff>()
+                        .eq(CheckDiff::getOrderCode, outTask.getTaskCode())
+                        .and(w -> w.isNull(CheckDiff::getOrderId).or().eq(CheckDiff::getOrderId, 0))
+                        .last("limit 1"));
+            }
+        }
+        if (checkDiff != null && !CheckDiffExceStatus.CHECK_DIFF_EXCE_STATUS_END.val.equals(checkDiff.getExceStatus())) {
+            checkDiffService.update(new LambdaUpdateWrapper<CheckDiff>()
+                    .eq(CheckDiff::getId, checkDiff.getId())
+                    .set(CheckDiff::getExceStatus, CheckDiffExceStatus.CHECK_DIFF_EXCE_STATUS_END.val));
+        }
     }
 
     /**
@@ -2221,7 +2253,9 @@
      */
     @Transactional(rollbackFor = Exception.class)
     public synchronized void complateInstock(Task task, Long loginUserId) {
-        if (Objects.isNull(task)) {
+        if (Objects.isNull(task)
+                ||task.getId().equals(5614L/*涓存椂璺宠繃*/)
+        ) {
             return;
         }
 

--
Gitblit v1.9.1