From f0a6462c539e217186d6fee31dfec6d2aba2e92a Mon Sep 17 00:00:00 2001 From: zxl <763096477@qq.com> Date: 星期二, 22 四月 2025 09:09:32 +0800 Subject: [PATCH] 点位在线率 --- ycl-server/src/main/java/com/ycl/platform/service/impl/CheckScoreServiceImpl.java | 27 +++++++++++++++++++++++++-- 1 files changed, 25 insertions(+), 2 deletions(-) diff --git a/ycl-server/src/main/java/com/ycl/platform/service/impl/CheckScoreServiceImpl.java b/ycl-server/src/main/java/com/ycl/platform/service/impl/CheckScoreServiceImpl.java index 57a706f..1e02d55 100644 --- a/ycl-server/src/main/java/com/ycl/platform/service/impl/CheckScoreServiceImpl.java +++ b/ycl-server/src/main/java/com/ycl/platform/service/impl/CheckScoreServiceImpl.java @@ -167,7 +167,7 @@ // } List<CheckScore> checkScores = scoreMapper.selectCheckScoreMap(checkScore); - + log.error("鎵撳嵃锛歿}",checkScores); // 濡傛灉鏁版嵁涓虹┖锛屽垯鏌ヨ涔嬪墠鐨勬暟鎹� if (CollectionUtils.isEmpty(checkScores) && (query.getStartDate() ==null || query.getStartDate() ==null)) { CheckScore one = scoreMapper.getLast(checkScore); @@ -180,7 +180,30 @@ } //鍒嗘暟淇濈暀涓�浣嶅皬鏁� checkScores.stream().forEach(item -> item.setScore(item.getScore().setScale(1, RoundingMode.HALF_UP))); - return checkScores.stream().collect(Collectors.groupingBy(CheckScore::getDeptId)); + Map<Long, List<CheckScore>> map = checkScores.stream().collect(Collectors.groupingBy(CheckScore::getDeptId)); + for (Map.Entry<Long, List<CheckScore>> entry : map.entrySet()) { + List<CheckScore> tempList = getCheckScores(entry); + // 杩唬缁撴潫鍚庯紝灏嗘柊鍏冪礌娣诲姞鍒板師濮嬪垪琛ㄤ腑 + entry.getValue().addAll(tempList); + } + return map; + } + + private List<CheckScore> getCheckScores(Map.Entry<Long, List<CheckScore>> entry) { + List<CheckScore> tempList = new ArrayList<>(); // 涓存椂瀛樺偍闇�瑕佹坊鍔犵殑鍏冪礌 + for (CheckScore listCheckScore : entry.getValue()) { + if (listCheckScore.getExamineCategory() == 1 && entry.getValue().size() == 1) { + CheckScore face = new CheckScore(); + face.setExamineCategory((short) 2); + face.setScore(new BigDecimal("0.0")); + CheckScore car = new CheckScore(); + car.setExamineCategory((short) 3); + car.setScore(new BigDecimal("0.0")); + tempList.add(face); + tempList.add(car); + } + } + return tempList; } private void getCheckScore(CheckScore checkScore) { -- Gitblit v1.8.0