From 36dcec12994c82fffe2a86a6acf12ecbd071fffb Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@163.com>
Date: 星期三, 08 一月 2025 16:26:18 +0800
Subject: [PATCH] #

---
 zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/CodeServiceImpl.java |   33 ++++++++++++++++++++++++++++++++-
 zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/CodeController.java    |   15 ++++++++++++++-
 zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/CodeService.java          |    4 ++++
 3 files changed, 50 insertions(+), 2 deletions(-)

diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/CodeController.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/CodeController.java
index d0e2cb7..3620b95 100644
--- a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/CodeController.java
+++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/CodeController.java
@@ -1,5 +1,6 @@
 package com.zy.acs.manager.manager.controller;
 
+import com.alibaba.fastjson.JSON;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.zy.acs.common.constant.CommonConstant;
@@ -14,7 +15,9 @@
 import com.zy.acs.manager.common.utils.ExcelUtil;
 import com.zy.acs.manager.manager.entity.Code;
 import com.zy.acs.manager.manager.service.CodeService;
+import com.zy.acs.manager.manager.service.impl.CodeServiceImpl;
 import com.zy.acs.manager.system.controller.BaseController;
+import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.security.access.prepost.PreAuthorize;
 import org.springframework.web.bind.annotation.*;
@@ -22,6 +25,7 @@
 import javax.servlet.http.HttpServletResponse;
 import java.util.*;
 
+@Slf4j
 @RestController
 @RequestMapping("/api")
 public class CodeController extends BaseController {
@@ -67,6 +71,9 @@
         code.setUpdateTime(new Date());
         if (!codeService.save(code)) {
             return R.error("Save Fail");
+        } else {
+            CodeServiceImpl.CODE_ID_CACHE.put(code.getId(), code);
+            CodeServiceImpl.CODE_DATA_CACHE.put(code.getData(), code);
         }
         return R.ok("Save Success").add(code);
     }
@@ -80,6 +87,9 @@
         code.setUpdateTime(new Date());
         if (!codeService.updateById(code)) {
             return R.error("Update Fail");
+        } else {
+            CodeServiceImpl.CODE_ID_CACHE.put(code.getId(), code);
+            CodeServiceImpl.CODE_DATA_CACHE.put(code.getData(), code);
         }
         return R.ok("Update Success").add(code);
     }
@@ -132,7 +142,10 @@
             code.setUpdateBy(userId);
             code.setUpdateTime(now);
             if (!codeService.save(code)) {
-
+                log.error("failed to save code {}", JSON.toJSONString(map));
+            } else {
+                CodeServiceImpl.CODE_ID_CACHE.put(code.getId(), code);
+                CodeServiceImpl.CODE_DATA_CACHE.put(code.getData(), code);
             }
         }
         return R.ok();
diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/CodeService.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/CodeService.java
index ebb4ea8..e7f9a5d 100644
--- a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/CodeService.java
+++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/CodeService.java
@@ -10,6 +10,10 @@
 
     Code selectByData(String data);
 
+    Code getCacheById(Long id);
+
+    Code getCacheByData(String data);
+
     void importExecute(List<CodeExcel> excelList);
 
     void adaptation(Double width, Double height);
diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/CodeServiceImpl.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/CodeServiceImpl.java
index 74bc3fe..a58ef16 100644
--- a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/CodeServiceImpl.java
+++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/CodeServiceImpl.java
@@ -3,6 +3,7 @@
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.zy.acs.common.utils.CodeUtils;
+import com.zy.acs.framework.common.Cools;
 import com.zy.acs.manager.common.domain.CodeExcel;
 import com.zy.acs.manager.common.exception.BusinessException;
 import com.zy.acs.manager.manager.entity.Code;
@@ -11,11 +12,12 @@
 import com.zy.acs.manager.manager.service.CodeGapService;
 import com.zy.acs.manager.manager.service.CodeService;
 import com.zy.acs.manager.manager.service.RouteService;
-import com.zy.acs.framework.common.Cools;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
+import javax.annotation.PostConstruct;
+import java.util.HashMap;
 import java.util.List;
 import java.util.Map;
 
@@ -27,12 +29,41 @@
     @Autowired
     private RouteService routeService;
 
+    public static final Map<Long, Code> CODE_ID_CACHE = new HashMap<>();
+    public static final Map<String, Code> CODE_DATA_CACHE = new HashMap<>();
+
+    @PostConstruct
+    public void init() {
+        for (Code code : this.list()) {
+            CODE_ID_CACHE.put(code.getId(), code);
+            CODE_DATA_CACHE.put(code.getData(), code);
+        }
+    }
+
     @Override
     public Code selectByData(String data) {
         return this.getOne(new LambdaQueryWrapper<Code>().eq(Code::getData, data));
     }
 
     @Override
+    public Code getCacheById(Long id) {
+        Code code = CODE_ID_CACHE.get(id);
+        if (code == null) {
+            code = this.getById(id);
+        }
+        return code;
+    }
+
+    @Override
+    public Code getCacheByData(String data) {
+        Code code = CODE_DATA_CACHE.get(data);
+        if (code == null) {
+            code = this.selectByData(data);
+        }
+        return code;
+    }
+
+    @Override
     public void importExecute(List<CodeExcel> excelList) {
         for (CodeExcel excel : excelList) {
             Code code = this.selectByData(excel.getCode());

--
Gitblit v1.9.1