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