From 29aa7746640d7d0c0f01f3e0d3f23ef3250086a7 Mon Sep 17 00:00:00 2001 From: zhang <zc857179121@qq.com> Date: 星期五, 13 六月 2025 16:50:39 +0800 Subject: [PATCH] 数据为空的校验补充 --- zy-acs-manager/src/main/java/com/zy/acs/manager/manager/service/impl/CodeServiceImpl.java | 61 +++++++++++++++++++++++++++++- 1 files changed, 58 insertions(+), 3 deletions(-) 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..35c0024 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,14 +12,18 @@ 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 lombok.extern.slf4j.Slf4j; 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.ArrayList; +import java.util.HashMap; import java.util.List; import java.util.Map; +@Slf4j @Service("codeService") public class CodeServiceImpl extends ServiceImpl<CodeMapper, Code> implements CodeService { @@ -27,9 +32,45 @@ @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); + } + log.info("The code cache was initialized..."); + } + @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); + if (code != null) { + CODE_ID_CACHE.put(id, code); + } + } + return code; + } + + @Override + public Code getCacheByData(String data) { + Code code = CODE_DATA_CACHE.get(data); + if (code == null) { + code = this.selectByData(data); + if (null != code) { + CODE_DATA_CACHE.put(data, code); + } + } + return code; } @Override @@ -138,8 +179,8 @@ Double maxY = Double.parseDouble(String.valueOf(map.get("max_y"))); // 缂╂斁鍚庨渶瑕佺殑鍋忕Щ閲� - double scaleOffsetX = width * (1 -CodeUtils.ADAPTATION_SCALE) / 2; - double scaleOffsetY = height * (1 -CodeUtils.ADAPTATION_SCALE) / 2; + double scaleOffsetX = width * (1 - CodeUtils.ADAPTATION_SCALE) / 2; + double scaleOffsetY = height * (1 - CodeUtils.ADAPTATION_SCALE) / 2; List<Code> codeList = this.list(); for (Code code : codeList) { @@ -167,4 +208,18 @@ return this.baseMapper.selectDistinctCountFromY(); } + @Override + public List<Code> getAllLocCode() { + List<Long> ids = this.baseMapper.selectAllLocCode(); + List<Code> codeList = new ArrayList<>(); + for (Long id : ids) { + Code byId = this.getById(id); + if (byId != null) { + codeList.add(byId); + } + + } + return codeList; + } + } -- Gitblit v1.9.1