From 83ba8a26cfc33a700d0de16ba9ad6e9229db0932 Mon Sep 17 00:00:00 2001
From: cl <1442464845@qq.com>
Date: 星期二, 07 四月 2026 17:40:01 +0800
Subject: [PATCH] 优化,部分历史明细被额外删除的bug

---
 src/main/java/com/zy/asrs/task/handler/OverYearLogHandler.java |   24 ++++++++++++++++++------
 1 files changed, 18 insertions(+), 6 deletions(-)

diff --git a/src/main/java/com/zy/asrs/task/handler/OverYearLogHandler.java b/src/main/java/com/zy/asrs/task/handler/OverYearLogHandler.java
index 62b7596..90bb425 100644
--- a/src/main/java/com/zy/asrs/task/handler/OverYearLogHandler.java
+++ b/src/main/java/com/zy/asrs/task/handler/OverYearLogHandler.java
@@ -20,12 +20,10 @@
     @Transactional
     public ReturnT<String> start() {
         try {
-            // 鍒犻櫎鍗婂勾浠ヤ笂鐨勫巻鍙叉。
-            jdbcTemplate.update("delete from asr_stk_hplc where dateadd(day,180,appe_time) <= getdate();");
-            jdbcTemplate.update("delete from asr_wrk_detl_log where dateadd(day,360,appe_time) <= getdate();");
-            jdbcTemplate.update("delete from asr_wrk_mast_log where dateadd(day,360,appe_time) <= getdate();");
-            jdbcTemplate.update("delete from cust_wait_pakin_log where dateadd(day,360,appe_time) <= getdate();");
-
+            batchDelete("asr_stk_hplc", "appe_time", 180);
+            batchDelete("asr_wrk_detl_log", "io_time", 360);
+            batchDelete("asr_wrk_mast_log", "io_time", 360);
+            batchDelete("cust_wait_pakin_log", "appe_time", 360);
         } catch (Exception e) {
             e.printStackTrace();
             TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
@@ -34,4 +32,18 @@
         return SUCCESS;
     }
 
+    @SuppressWarnings("SameParameterValue")
+    private void batchDelete(String tableName, String time, int days) {
+        int batchSize = 1000;
+        int affected;
+        do {
+            String sql = String.format(
+                    "WITH cte AS (SELECT TOP (%d) * FROM %s WHERE dateadd(day, %d, %s) <= getdate()) DELETE FROM cte",
+                    batchSize, tableName, days, time
+            );
+            affected = jdbcTemplate.update(sql);
+        } while (affected > 0);
+    }
+
+
 }

--
Gitblit v1.9.1