From 6d5ce70c3e2b536c8e4b74269be70029a57cb1cc Mon Sep 17 00:00:00 2001
From: 云 <2163098428@qq.com>
Date: 星期一, 11 五月 2026 15:36:32 +0800
Subject: [PATCH] feat(approve): 使用通用工具类优化审批流程ID生成逻辑

---
 src/main/java/com/ruoyi/approve/service/impl/ApproveProcessServiceImpl.java |   12 ++---
 src/main/java/com/ruoyi/common/utils/OrderUtils.java                        |   51 +++++++++++++++++++++++++
 2 files changed, 56 insertions(+), 7 deletions(-)

diff --git a/src/main/java/com/ruoyi/approve/service/impl/ApproveProcessServiceImpl.java b/src/main/java/com/ruoyi/approve/service/impl/ApproveProcessServiceImpl.java
index 92ad324..f0b6222 100644
--- a/src/main/java/com/ruoyi/approve/service/impl/ApproveProcessServiceImpl.java
+++ b/src/main/java/com/ruoyi/approve/service/impl/ApproveProcessServiceImpl.java
@@ -16,6 +16,7 @@
 import com.ruoyi.approve.vo.ApproveGetAndUpdateVo;
 import com.ruoyi.approve.vo.ApproveProcessVO;
 import com.ruoyi.common.enums.FileNameType;
+import com.ruoyi.common.utils.OrderUtils;
 import com.ruoyi.other.service.impl.TempFileServiceImpl;
 import com.ruoyi.project.system.domain.SysDept;
 import com.ruoyi.project.system.domain.SysNotice;
@@ -85,14 +86,11 @@
         if (CollectionUtils.isEmpty(sysUsers)) throw new RuntimeException("瀹℃牳鐢ㄦ埛涓嶅瓨鍦�");
         if (sysDept == null) throw new RuntimeException("閮ㄩ棬涓嶅瓨鍦�");
         if (sysUser == null) throw new RuntimeException("鐢宠浜轰笉瀛樺湪");
-        String today = LocalDate.now().format(DATE_FORMAT);
-        Long approveId = dailyRedisCounter.incrementAndGetByDb();
-        String formattedCount = String.format("%03d", approveId);
-        //娴佺▼ ID
-        String approveID = today + formattedCount;
+
         SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
         ApproveProcess approveProcess = new ApproveProcess();
-        approveProcess.setApproveId(approveID);
+        String no = OrderUtils.countTodayByCreateTime(approveProcessMapper, "", "approve_id");
+        approveProcess.setApproveId(no);
         approveProcess.setApproveUser(approveProcessVO.getApproveUser());
         approveProcess.setApproveUserName(sysUser.getNickName());
         approveProcess.setApproveDeptId(approveProcessVO.getApproveDeptId());
@@ -130,7 +128,7 @@
         }
         save(approveProcess);
         //鍒濆鍖栧鎵硅妭鐐�
-        approveNodeService.initApproveNodes(approveProcessVO.getApproveUserIds(), approveID, approveProcessVO.getApproveDeptId(),approveProcess.getId());
+        approveNodeService.initApproveNodes(approveProcessVO.getApproveUserIds(), no, approveProcessVO.getApproveDeptId(),approveProcess.getId());
         // 闄勪欢缁戝畾
         tempFileService.migrateTempFilesToFormal(approveProcess.getId(), approveProcessVO.getTempFileIds(), FileNameType.ApproveProcess.getValue());
         /*娑堟伅閫氱煡*/
diff --git a/src/main/java/com/ruoyi/common/utils/OrderUtils.java b/src/main/java/com/ruoyi/common/utils/OrderUtils.java
index 52df76b..bd3ac49 100644
--- a/src/main/java/com/ruoyi/common/utils/OrderUtils.java
+++ b/src/main/java/com/ruoyi/common/utils/OrderUtils.java
@@ -13,6 +13,7 @@
 import java.time.format.DateTimeFormatter;
 import java.util.Date;
 import java.util.HashMap;
+import java.util.List;
 import java.util.Map;
 
 /**
@@ -54,4 +55,54 @@
         // 鎷兼帴璁㈠崟缂栧彿 preFix + 鏃堕棿锛坹yyyMMdd锛� + 璁㈠崟鏁伴噺(001)
         return preFix + LocalDate.now().format(DateTimeFormatter.ISO_LOCAL_DATE).replaceAll("-", "") + String.format("%03d", (aLong + 1)) + "-" + new Date().getTime();
     }
+
+    /**
+     * 鏌ヨ褰撳ぉ鍩轰簬 create_time 鐨勬渶鏂扮紪鍙凤紝骞剁敓鎴愪笅涓�涓紪鍙�
+     * @param mapper mapper
+     * @param preFix 缂栧彿鍓嶇紑
+     * @param code 缂栧彿瀛楁
+     * @param <T> 瀹炰綋绫诲瀷
+     * @return 璁㈠崟缂栧彿
+     */
+    public static <T> String countTodayByCreateTime(BaseMapper<T> mapper,String preFix,String code) {
+        LocalDate today = LocalDate.now();
+        LocalDateTime todayStart = today.atStartOfDay();
+        LocalDateTime tomorrowStart = today.plusDays(1).atStartOfDay();
+        String dateStr = today.format(DateTimeFormatter.BASIC_ISO_DATE);
+        String codePrefix = preFix + dateStr;
+
+        QueryWrapper<T> wrapper = new QueryWrapper<>();
+        wrapper.select(code)
+                .ge("create_time", todayStart)
+                .lt("create_time", tomorrowStart)
+                .likeRight(code, codePrefix)
+                .orderByDesc(code)
+                .last("LIMIT 1");
+
+        long nextSeq = 1;
+        List<Map<String, Object>> records = mapper.selectMaps(wrapper);
+        if (!records.isEmpty()) {
+            Object lastCode = records.get(0).get(code);
+            if (lastCode != null) {
+                nextSeq = extractSequence(lastCode.toString(), codePrefix) + 1;
+            }
+        }
+
+        return preFix + dateStr + String.format("%03d", nextSeq);
+    }
+
+    private static long extractSequence(String fullCode, String codePrefix) {
+        if (!fullCode.startsWith(codePrefix)) {
+            return 0;
+        }
+        String seqStr = fullCode.substring(codePrefix.length()).trim();
+        if (seqStr.isEmpty()) {
+            return 0;
+        }
+        try {
+            return Long.parseLong(seqStr);
+        } catch (NumberFormatException e) {
+            return 0;
+        }
+    }
 }

--
Gitblit v1.9.3