From aad28a866d7d200e1228f7a5d053348e7f9653a4 Mon Sep 17 00:00:00 2001 From: zss <zss@example.com> Date: 星期二, 17 十二月 2024 13:47:38 +0800 Subject: [PATCH] 统计+首页+电路试验提交bug --- inspect-server/src/main/java/com/yuanchu/mom/service/ReportService.java | 12 ++- inspect-server/src/main/java/com/yuanchu/mom/utils/WordUtils.java | 2 inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderPlanServiceImpl.java | 2 inspect-server/src/main/java/com/yuanchu/mom/controller/ReportController.java | 22 ++++- inspect-server/src/main/java/com/yuanchu/mom/service/impl/ReportServiceImpl.java | 171 +++++++++++++++++++++++++++++++++++------- inspect-server/src/main/java/com/yuanchu/mom/dto/AuxiliaryOutputWorkingHoursDto.java | 15 +++ 6 files changed, 187 insertions(+), 37 deletions(-) diff --git a/inspect-server/src/main/java/com/yuanchu/mom/controller/ReportController.java b/inspect-server/src/main/java/com/yuanchu/mom/controller/ReportController.java index eeb5f00..bc672bf 100644 --- a/inspect-server/src/main/java/com/yuanchu/mom/controller/ReportController.java +++ b/inspect-server/src/main/java/com/yuanchu/mom/controller/ReportController.java @@ -24,14 +24,14 @@ @ValueClassify("缁熻鍥捐〃") @ApiOperation(value = "鏌ヨ姣忔棩涓氬姟缁熻") @GetMapping("/businessStatisticsByDay") - public Result businessStatisticsByDay(){ - return Result.success(reportService.businessStatisticsByDay()); + public Result businessStatisticsByDay(String startTime,String endTime,String type){ + return Result.success(reportService.businessStatisticsByDay(startTime,endTime,type)); } @ValueClassify("缁熻鍥捐〃") @ApiOperation(value = "鏌ヨ妫�娴嬮」鐩粺璁�") @GetMapping("/testProductByDay") - public Result testProductByDay(){ - return Result.success(reportService.testProductByDay()); + public Result testProductByDay(String startTime,String endTime,String type){ + return Result.success(reportService.testProductByDay(startTime,endTime,type)); } @ValueAuth @ApiOperation(value = "鏌ヨ鏃ュ巻浠诲姟鍥�") @@ -52,4 +52,18 @@ public Result ScheduleByMe(String date){ return Result.success(reportService.ScheduleByMe(date)); } + + @ValueAuth + @ApiOperation(value = "鍚勭珯鐐瑰伐鏃�") + @PostMapping("/manHourByStation") + public Result manHourByStation(String startTime,String endTime){ + return Result.success(reportService.manHourByStation(startTime,endTime)); + } + + @ValueAuth + @ApiOperation(value = "鍚勭珯鐐瑰伐鏃舵瘡涓汉鎵�鍗犵櫨鍒嗘瘮") + @PostMapping("/manHourByPerson") + public Result manHourByPerson(String startTime,String endTime){ + return Result.success(reportService.manHourByPerson(startTime,endTime)); + } } diff --git a/inspect-server/src/main/java/com/yuanchu/mom/dto/AuxiliaryOutputWorkingHoursDto.java b/inspect-server/src/main/java/com/yuanchu/mom/dto/AuxiliaryOutputWorkingHoursDto.java new file mode 100644 index 0000000..7ec0db1 --- /dev/null +++ b/inspect-server/src/main/java/com/yuanchu/mom/dto/AuxiliaryOutputWorkingHoursDto.java @@ -0,0 +1,15 @@ +package com.yuanchu.mom.dto; + +import com.yuanchu.mom.pojo.AuxiliaryOutputWorkingHours; +import lombok.Data; + +@Data +public class AuxiliaryOutputWorkingHoursDto extends AuxiliaryOutputWorkingHours { + + //绔欑偣 + private String sonLaboratory; + + private String getSonLaboratoryFromDto(AuxiliaryOutputWorkingHoursDto dto) { + return dto.getSonLaboratory(); + } +} diff --git a/inspect-server/src/main/java/com/yuanchu/mom/service/ReportService.java b/inspect-server/src/main/java/com/yuanchu/mom/service/ReportService.java index ff1bf71..c4bd75b 100644 --- a/inspect-server/src/main/java/com/yuanchu/mom/service/ReportService.java +++ b/inspect-server/src/main/java/com/yuanchu/mom/service/ReportService.java @@ -3,18 +3,16 @@ import com.yuanchu.mom.pojo.Schedule; -import java.time.LocalDate; -import java.time.LocalDateTime; import java.util.List; import java.util.Map; public interface ReportService { //姣忔棩涓氬姟缁熻 - Map<String,Object> businessStatisticsByDay(); + Map<String,Object> businessStatisticsByDay(String startTime,String endTime,String type); //妫�娴嬮」鐩粺璁� - Map<String,Object> testProductByDay(); + Map<String,Object> testProductByDay(String startTime,String endTime,String type); //棣栭〉-->鏃ュ巻浠诲姟鍥� Map<String,Object> calendarWorkByWeek(); @@ -24,4 +22,10 @@ //棣栭〉-->鎴戠殑鏃ョ▼ List<Schedule> ScheduleByMe(String date); + + //棣栭〉-->鍚勭珯鐐瑰伐鏃� + Map<String,Double> manHourByStation(String startTime,String endTime); + + //棣栭〉-->鍚勭珯鐐瑰伐鏃舵瘡涓汉鎵�鍗犵櫨鍒嗘瘮 + Map<String, Map<String, Double>> manHourByPerson(String startTime, String endTime); } diff --git a/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderPlanServiceImpl.java b/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderPlanServiceImpl.java index 7b7aded..b3a28d5 100644 --- a/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderPlanServiceImpl.java +++ b/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderPlanServiceImpl.java @@ -1204,7 +1204,7 @@ insSampleUserMapper.insert(insSampleUser); /*鐢熸垚鐢佃矾璇曢獙鐨勭珯鐐规姤鍛婂苟涓婁紶鍒伴檮浠朵腑*/ if (submitPlanDto.getLaboratory().equals("鐢佃矾璇曢獙")) { - //wordUtils.generateWord(submitPlanDto.getTerm(), orderState); +// wordUtils.generateWord(submitPlanDto.getTerm(), orderState); //todo 鐢佃矾绔欑偣鎶ュ憡 姝e紡搴撻儴缃叉斁寮� try { wordUtils.generateWord(submitPlanDto.getTerm(), orderState); diff --git a/inspect-server/src/main/java/com/yuanchu/mom/service/impl/ReportServiceImpl.java b/inspect-server/src/main/java/com/yuanchu/mom/service/impl/ReportServiceImpl.java index db0d87e..907fc32 100644 --- a/inspect-server/src/main/java/com/yuanchu/mom/service/impl/ReportServiceImpl.java +++ b/inspect-server/src/main/java/com/yuanchu/mom/service/impl/ReportServiceImpl.java @@ -6,11 +6,13 @@ import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.yuanchu.mom.common.GetLook; +import com.yuanchu.mom.dto.AuxiliaryOutputWorkingHoursDto; import com.yuanchu.mom.dto.CostStatisticsDto; import com.yuanchu.mom.mapper.*; import com.yuanchu.mom.pojo.*; import com.yuanchu.mom.service.ReportService; import lombok.AllArgsConstructor; +import org.springframework.beans.BeanUtils; import org.springframework.stereotype.Service; import java.math.BigDecimal; @@ -33,27 +35,55 @@ private UserMapper userMapper; private RoleMapper roleMapper; private InsSampleUserMapper insSampleUserMapper; + private AuxiliaryOutputWorkingHoursMapper auxiliaryOutputWorkingHoursMapper; //姣忔棩涓氬姟缁熻 @Override - public Map<String, Object> businessStatisticsByDay() { + public Map<String, Object> businessStatisticsByDay(String startTime,String endTime,String type) { + DateTimeFormatter format = DateTimeFormatter.ofPattern("yyyy-MM-dd"); + LocalDateTime start = LocalDate.parse(startTime, format).atStartOfDay(); + LocalDateTime end = LocalDate.parse(endTime, format).atTime(23, 59, 59); + LocalDateTime oldStart=start ; + LocalDateTime oldEnd=end ; + switch (type){ + case "鍛�": + oldStart = start.minusDays(7); + oldEnd = end.minusDays(7); + break; + case "鏈�": + oldStart = start.minusMonths(1); + oldEnd = end.minusMonths(1); + break; + case "骞�": + oldStart = start.minusYears(1); + oldEnd = end.minusYears(1); + break; + } Map<String, Object> map = new HashMap<>(); /*浠诲姟鎺ユ敹*/ //浠婃棩浠诲姟鎺ユ敹 - Long receive = insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery().eq(InsOrder::getState, 1).apply("DATE(create_time) = CURDATE()")); + Long receive = insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery() + .eq(InsOrder::getState, 1) + .between(InsOrder::getCreateTime, start, end)); map.put("RECEIVE", receive); //鏄ㄦ棩浠诲姟鎺ユ敹 - Long received = insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery().eq(InsOrder::getState, 1).apply("DATE(create_time) = CURDATE() - INTERVAL 1 DAY")); + Long received = insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery() + .eq(InsOrder::getState, 1) + .between(InsOrder::getCreateTime, oldStart, oldEnd)); //姣斾緥=(浠婂ぉ-鏄ㄥぉ)/鏄ㄥぉ BigDecimal ratio = new BigDecimal(receive - received).divide(new BigDecimal(received == 0 ? 1 : received), 2, BigDecimal.ROUND_HALF_UP); map.put("RECEIVE_RATIO", ratio); /*浠诲姟宸插畬鎴�*/ //浠婃棩浠诲姟瀹屾垚 - Long finishe = insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery().eq(InsOrder::getState, 4).apply("DATE(create_time) = CURDATE()")); + Long finishe = insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery() + .eq(InsOrder::getState, 4) + .between(InsOrder::getCreateTime, start, end)); map.put("FINISHE", finishe); //鏄ㄦ棩浠诲姟瀹屾垚 - Long finished = insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery().eq(InsOrder::getState, 4).apply("DATE(create_time) = CURDATE() - INTERVAL 1 DAY")); + Long finished = insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery() + .eq(InsOrder::getState, 4) + .between(InsOrder::getCreateTime, oldStart, oldEnd)); //浠诲姟瀹屾垚姣斾緥=(浠婂ぉ-鏄ㄥぉ)/鏄ㄥぉ BigDecimal finishedRatio = new BigDecimal(finishe - finished).divide(new BigDecimal(finished == 0 ? 1 : finished), 2, BigDecimal.ROUND_HALF_UP); map.put("FINISHE_RATIO", finishedRatio); @@ -71,7 +101,7 @@ /*妫�娴嬭垂鐢�*/ //浠婃棩妫�娴嬭垂鐢� QueryWrapper<CostStatisticsDto> costStatisticsDtoQueryWrappers = new QueryWrapper<>(); - costStatisticsDtoQueryWrappers.eq("create_time", LocalDateTime.now()); + costStatisticsDtoQueryWrappers.between("create_time", start,end); IPage<CostStatisticsDto> page = new Page<>(); page.setSize(-1); page.setCurrent(-1); @@ -83,7 +113,7 @@ map.put("PRICE", price); //鏄ㄦ棩妫�娴嬭垂鐢� QueryWrapper<CostStatisticsDto> costWrappers = new QueryWrapper<>(); - costWrappers.eq("create_time", LocalDateTime.now().minusDays(1)); + costWrappers.between("create_time", oldStart,oldEnd); IPage<CostStatisticsDto> dtoIPage = insOrderMapper.selectCostStatistics(page, costWrappers); BigDecimal priced = BigDecimal.ZERO; for (CostStatisticsDto record : dtoIPage.getRecords()) { @@ -112,11 +142,13 @@ /*妫�娴嬩汉鍛�*/ //浠婃棩妫�娴嬩汉鍛� - List<InsProductUser> insProductUsers = insProductUserMapper.selectList(Wrappers.<InsProductUser>lambdaQuery().apply("DATE(create_time) = CURDATE()")); + List<InsProductUser> insProductUsers = insProductUserMapper.selectList(Wrappers.<InsProductUser>lambdaQuery() + .between(InsProductUser::getCreateTime, start, end)); long person = insProductUsers.stream().map(InsProductUser::getCreateUser).distinct().count(); map.put("PERSON", person); //鏄ㄦ棩妫�娴嬩汉鍛� - List<InsProductUser> insProductUserss = insProductUserMapper.selectList(Wrappers.<InsProductUser>lambdaQuery().apply("DATE(create_time) = CURDATE() - INTERVAL 1 DAY")); + List<InsProductUser> insProductUserss = insProductUserMapper.selectList(Wrappers.<InsProductUser>lambdaQuery() + .between(InsProductUser::getCreateTime, oldStart, oldEnd)); long persons = insProductUserss.stream().map(InsProductUser::getCreateUser).distinct().count(); //姣斾緥=(浠婂ぉ-鏄ㄥぉ)/鏄ㄥぉ BigDecimal personRatio = new BigDecimal(person - persons).divide(new BigDecimal(persons == 0 ? 1 : persons), 2, BigDecimal.ROUND_HALF_UP); @@ -124,14 +156,20 @@ /*杩戝崄鏃ヤ换鍔℃帴鏀堕噺涓庡畬鎴愰噺*/ //鑾峰彇杩戝崄鏃ョ殑妯潗鏍� - LocalDate currentDate = LocalDate.now(); + LocalDate startDate = LocalDate.parse(startTime, format); + LocalDate endDate = LocalDate.parse(endTime, format); List<LocalDate> lastTenDays = new ArrayList<>(); List<Long> receTenDays = new ArrayList<>(); List<Long> finTenDays = new ArrayList<>(); - for (int i = 9; i > -1; i--) { - lastTenDays.add(currentDate.minusDays(i)); - receTenDays.add(insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery().eq(InsOrder::getState, 1).apply("DATE(create_time) = CURDATE() - INTERVAL " + i + " DAY"))); - finTenDays.add(insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery().eq(InsOrder::getState, 4).apply("DATE(create_time) = CURDATE() - INTERVAL " + i + " DAY"))); + while (!startDate.isAfter(endDate)) { + lastTenDays.add(startDate); + receTenDays.add(insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery() + .eq(InsOrder::getState, 1) + .between(InsOrder::getCreateTime,startDate.atStartOfDay(),startDate.atTime(23,59,59)))); + finTenDays.add(insOrderMapper.selectCount(Wrappers.<InsOrder>lambdaQuery() + .eq(InsOrder::getState, 4) + .between(InsOrder::getCreateTime,startDate.atStartOfDay(),startDate.atTime(23,59,59)))); + startDate = startDate.plusDays(1); } map.put("DAYS", lastTenDays); map.put("RECETENDAYS", receTenDays); @@ -141,24 +179,39 @@ //妫�娴嬮」鐩粺璁� @Override - public Map<String, Object> testProductByDay() { + public Map<String, Object> testProductByDay(String startTime,String endTime,String type) { + DateTimeFormatter format = DateTimeFormatter.ofPattern("yyyy-MM-dd"); + LocalDateTime start = LocalDate.parse(startTime, format).atStartOfDay(); + LocalDateTime end = LocalDate.parse(endTime, format).atTime(23, 59, 59); + LocalDateTime oldStart=start ; + LocalDateTime oldEnd=end ; Map<String, Object> map = new HashMap<>(); /*椤圭洰鎺ユ敹*/ //浠婃棩椤圭洰鎺ユ敹閲� - Long receive = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getState, 1).apply("DATE(create_time) = CURDATE()")); + Long receive = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery() + .eq(InsProduct::getState, 1) + .between(InsProduct::getCreateTime, start, end)); map.put("RECEVICE", receive); //鏄ㄦ棩椤圭洰鎺ユ敹閲� - Long received = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getState, 1).apply("DATE(create_time) = CURDATE() - INTERVAL 1 DAY")); + Long received = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery() + .eq(InsProduct::getState, 1) + .between(InsProduct::getCreateTime, oldStart, oldEnd)); //姣斾緥=(浠婂ぉ-鏄ㄥぉ)/鏄ㄥぉ BigDecimal ratio = new BigDecimal(receive - received).divide(new BigDecimal(received == 0 ? 1 : received), 2, BigDecimal.ROUND_HALF_UP); map.put("RECEIVE_RATIO", ratio); /*椤圭洰瀹屾垚*/ //浠婃棩椤圭洰瀹屾垚閲� - Long finishe = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getState, 1).isNotNull(InsProduct::getInsResult).apply("DATE(create_time) = CURDATE()")); + Long finishe = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery() + .eq(InsProduct::getState, 1) + .isNotNull(InsProduct::getInsResult) + .between(InsProduct::getCreateTime, start, end)); map.put("FINISHE", finishe); //鏄ㄦ棩椤圭洰瀹屾垚閲� - Long finished = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getState, 1).isNotNull(InsProduct::getInsResult).apply("DATE(create_time) = CURDATE() - INTERVAL 1 DAY")); + Long finished = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery() + .eq(InsProduct::getState, 1) + .isNotNull(InsProduct::getInsResult) + .between(InsProduct::getCreateTime, oldStart, oldEnd)); //浠诲姟瀹屾垚姣斾緥=(浠婂ぉ-鏄ㄥぉ)/鏄ㄥぉ BigDecimal finishedRatio = new BigDecimal(finishe - finished).divide(new BigDecimal(finished == 0 ? 1 : finished), 2, BigDecimal.ROUND_HALF_UP); map.put("FINISHE_RATIO", finishedRatio); @@ -175,7 +228,10 @@ /*浠婃棩椤圭洰鍚堟牸鐜�*/ //浠婃棩瀹屾垚閲忎腑鐨勫悎鏍奸噺/浠婃棩瀹屾垚閲� - Long accept = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getState, 1).eq(InsProduct::getInsResult,1).apply("DATE(create_time) = CURDATE()")); + Long accept = insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery() + .eq(InsProduct::getState, 1) + .eq(InsProduct::getInsResult, 1) + .between(InsProduct::getCreateTime, start, end)); map.put("ACCEPT", accept); BigDecimal acceptRate = new BigDecimal(accept).divide(new BigDecimal(finishe == 0 ? 1 : finishe), 2, BigDecimal.ROUND_HALF_UP); map.put("ACCEPT_RATE_TODAY", acceptRate); @@ -192,14 +248,21 @@ /*杩戝崄鏃ョ殑椤圭洰鎺ユ敹閲忎笌瀹屾垚閲�*/ //鑾峰彇杩戝崄鏃ョ殑妯潗鏍� - LocalDate currentDate = LocalDate.now(); + LocalDate startDate = LocalDate.parse(startTime, format); + LocalDate endDate = LocalDate.parse(endTime, format); List<LocalDate> lastTenDays = new ArrayList<>(); List<Long> receTenDays = new ArrayList<>(); List<Long> finTenDays = new ArrayList<>(); - for (int i = 9; i > -1; i--) { - lastTenDays.add(currentDate.minusDays(i)); - receTenDays.add(insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getState, 1).apply("DATE(create_time) = CURDATE() - INTERVAL " + i + " DAY"))); - finTenDays.add(insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getState, 1).isNotNull(InsProduct::getInsResult).apply("DATE(create_time) = CURDATE() - INTERVAL " + i + " DAY"))); + while (!startDate.isAfter(endDate)) { + lastTenDays.add(startDate); + receTenDays.add(insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery() + .eq(InsProduct::getState, 1) + .between(InsProduct::getCreateTime,startDate.atStartOfDay(),startDate.atTime(23,59,59)))); + finTenDays.add(insProductMapper.selectCount(Wrappers.<InsProduct>lambdaQuery() + .eq(InsProduct::getState, 1) + .isNotNull(InsProduct::getInsResult) + .between(InsProduct::getCreateTime,startDate.atStartOfDay(),startDate.atTime(23,59,59)))); + startDate = startDate.plusDays(1); } map.put("DAYS", lastTenDays); map.put("RECETENDAYS", receTenDays); @@ -228,18 +291,19 @@ .in(InsOrder::getInsState, insState) .apply("DATE(create_time) = CURDATE() - INTERVAL " + j + " DAY")); //濡傛灉褰撳墠鐧诲綍浜烘槸娴嬭瘯宸ョ▼甯堟垨鑰呮槸妫�娴嬬粍闀�,闇�瑕佽繃婊ゅ嚭妫�楠屼汉鏄粬浠殑璁㈠崟鎴栬�呮槸杩樻病妫�楠岀殑璁㈠崟 - if (name.equals("娴嬭瘯宸ョ▼甯�") || name.equals("妫�娴嬬粍闀�")){ + if (name.equals("娴嬭瘯宸ョ▼甯�") || name.equals("妫�娴嬬粍闀�")) { insOrders = insOrders.stream().filter(insOrder -> { List<InsSample> insSamples = insSampleMapper.selectList(Wrappers.<InsSample>lambdaQuery().eq(InsSample::getInsOrderId, insOrder.getId())); List<Integer> sampleId = insSamples.stream().map(InsSample::getId).collect(Collectors.toList()); List<InsSampleUser> insSampleUsers = insSampleUserMapper.selectList(Wrappers.<InsSampleUser>lambdaQuery() + .in(InsSampleUser::getInsSampleId, sampleId) .eq(InsSampleUser::getState, 0) //妫�楠屼汉 - .in(InsSampleUser::getInsSampleId, sampleId)); + ); return insSampleUsers.size() == 0 || insSampleUsers.stream().map(InsSampleUser::getUserId).collect(Collectors.toList()).contains(userId); }).collect(Collectors.toList()); } //濡傛灉褰撳墠鐧诲綍浜烘槸閫佹牱鍛�,闇�杩囨护鍑哄崟瀛愮殑閫佹牱鍛樻槸褰撳墠浜虹殑璁㈠崟 - else if (name.equals("閫佹牱鍛�")){ + else if (name.equals("閫佹牱鍛�")) { insOrders = insOrders.stream().filter(insOrder -> ObjectUtils.isNotEmpty(insOrder.getIssueUser()) && insOrder.getIssueUser().equals(userId) ).collect(Collectors.toList()); @@ -283,4 +347,55 @@ LocalDateTime endTime = localDate.plusDays(1).atStartOfDay().minusSeconds(1); return scheduleMapper.selectList(Wrappers.<Schedule>lambdaQuery().eq(Schedule::getUserId, userId).between(Schedule::getScheduleTime, startTime, endTime)); } + + //棣栭〉-->鍚勭珯鐐圭殑宸ユ椂 + @Override + public Map<String, Double> manHourByStation(String startTime, String endTime) { + DateTimeFormatter format = DateTimeFormatter.ofPattern("yyyy-MM-dd"); + LocalDateTime start = LocalDate.parse(startTime, format).atStartOfDay(); + LocalDateTime end = LocalDate.parse(endTime, format).atTime(23, 59, 59); + //鏌ヨ杩欎釜鏃堕棿鍐呮墍鏈夌殑宸ユ椂 + List<AuxiliaryOutputWorkingHours> auxiliaryOutputWorkingHours = auxiliaryOutputWorkingHoursMapper.selectList(Wrappers.<AuxiliaryOutputWorkingHours>lambdaQuery() + .between(AuxiliaryOutputWorkingHours::getCreateTime, start, end)); + //鏍规嵁妫�楠岄」鏌ュ嚭鏉ョ殑绔欑偣杩涜鍒嗙被 + List<AuxiliaryOutputWorkingHoursDto> outputWorkingHoursDtos = auxiliaryOutputWorkingHours.stream().map(auxiliaryOutputWorkingHours1 -> { + AuxiliaryOutputWorkingHoursDto auxiliaryOutputWorkingHoursDto = new AuxiliaryOutputWorkingHoursDto(); + BeanUtils.copyProperties(auxiliaryOutputWorkingHours1, auxiliaryOutputWorkingHoursDto); + InsProduct insProduct = insProductMapper.selectById(auxiliaryOutputWorkingHours1.getInsProductId()); + auxiliaryOutputWorkingHoursDto.setSonLaboratory(insProduct.getSonLaboratory()); + return auxiliaryOutputWorkingHoursDto; + }).collect(Collectors.toList()); + Map<String, Double> map = outputWorkingHoursDtos.stream() + .collect(Collectors.groupingBy( + AuxiliaryOutputWorkingHoursDto::getSonLaboratory, + Collectors.summingDouble(AuxiliaryOutputWorkingHours::getOutputWorkTime))); + return map; + } + + //棣栭〉-->鍚勭珯鐐瑰伐鏃舵瘡涓汉鎵�鍗犵櫨鍒嗘瘮 + @Override + public Map<String, Map<String, Double>> manHourByPerson(String startTime, String endTime) { + DateTimeFormatter format = DateTimeFormatter.ofPattern("yyyy-MM-dd"); + LocalDateTime start = LocalDate.parse(startTime, format).atStartOfDay(); + LocalDateTime end = LocalDate.parse(endTime, format).atTime(23, 59, 59); + //鏌ヨ杩欎釜鏃堕棿鍐呮墍鏈夌殑宸ユ椂 + List<AuxiliaryOutputWorkingHours> auxiliaryOutputWorkingHours = auxiliaryOutputWorkingHoursMapper.selectList(Wrappers.<AuxiliaryOutputWorkingHours>lambdaQuery() + .between(AuxiliaryOutputWorkingHours::getCreateTime, start, end)); + //鏍规嵁妫�楠岄」鏌ュ嚭鏉ョ殑绔欑偣杩涜鍒嗙被 + List<AuxiliaryOutputWorkingHoursDto> outputWorkingHoursDtos = auxiliaryOutputWorkingHours.stream().map(auxiliaryOutputWorkingHours1 -> { + AuxiliaryOutputWorkingHoursDto auxiliaryOutputWorkingHoursDto = new AuxiliaryOutputWorkingHoursDto(); + BeanUtils.copyProperties(auxiliaryOutputWorkingHours1, auxiliaryOutputWorkingHoursDto); + InsProduct insProduct = insProductMapper.selectById(auxiliaryOutputWorkingHours1.getInsProductId()); + auxiliaryOutputWorkingHoursDto.setSonLaboratory(insProduct.getSonLaboratory()); + return auxiliaryOutputWorkingHoursDto; + }).collect(Collectors.toList()); + Map<String, Map<String, Double>> mapMap = outputWorkingHoursDtos.stream() + .collect(Collectors.groupingBy( + AuxiliaryOutputWorkingHoursDto::getSonLaboratory, + Collectors.groupingBy( + t -> userMapper.selectById(t.getCheck()).getName(), + Collectors.summingDouble(AuxiliaryOutputWorkingHours::getOutputWorkTime)))); + + return mapMap; + } } diff --git a/inspect-server/src/main/java/com/yuanchu/mom/utils/WordUtils.java b/inspect-server/src/main/java/com/yuanchu/mom/utils/WordUtils.java index 2ab885a..0eebbe8 100644 --- a/inspect-server/src/main/java/com/yuanchu/mom/utils/WordUtils.java +++ b/inspect-server/src/main/java/com/yuanchu/mom/utils/WordUtils.java @@ -106,6 +106,7 @@ InsSample insSample = insSampleMapper.selectById(insOrderState.getInsSampleId()); //鏌ヨ椤圭洰 List<InsProduct> insProducts = insProductMapper.selectList(Wrappers.<InsProduct>lambdaQuery() + .eq(InsProduct::getState,1) .eq(InsProduct::getInsSampleId, insSample.getId()) .eq(InsProduct::getSonLaboratory, "鐢佃矾璇曢獙")); //鑾峰彇鏈�澶х鍙f暟閲�,瑙掑害鏁伴噺,棰戞鏁伴噺 @@ -2337,6 +2338,7 @@ //鏌ヨ椤圭洰 List<InsProduct> insProducts = insProductMapper.selectList(Wrappers.<InsProduct>lambdaQuery() + .eq(InsProduct::getState,1) .eq(InsProduct::getInsSampleId, insSample.getId()) .eq(InsProduct::getSonLaboratory, "鐢佃矾璇曢獙")); //鑾峰彇鏈�澶х鍙f暟閲�,瑙掑害鏁伴噺,棰戞鏁伴噺 -- Gitblit v1.9.3