From d268f82d25c25ebdc7a1ea30614f6cda6d3a9ae3 Mon Sep 17 00:00:00 2001 From: fuliqi <fuliqi@qq.com> Date: 星期四, 10 十月 2024 16:31:41 +0800 Subject: [PATCH] win库+大屏考核指标查询bug --- ycl-server/src/main/java/com/ycl/platform/service/impl/TMonitorServiceImpl.java | 707 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 701 insertions(+), 6 deletions(-) diff --git a/ycl-server/src/main/java/com/ycl/platform/service/impl/TMonitorServiceImpl.java b/ycl-server/src/main/java/com/ycl/platform/service/impl/TMonitorServiceImpl.java index 44c5f48..78ff3c8 100644 --- a/ycl-server/src/main/java/com/ycl/platform/service/impl/TMonitorServiceImpl.java +++ b/ycl-server/src/main/java/com/ycl/platform/service/impl/TMonitorServiceImpl.java @@ -3,39 +3,73 @@ import annotation.DataScope; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.mongodb.client.AggregateIterable; +import com.mongodb.client.MongoCollection; +import com.mongodb.client.MongoDatabase; import com.ycl.platform.domain.entity.TMonitor; +import com.ycl.platform.domain.excel.VideoDailyExp; +import com.ycl.platform.domain.excel.VideoTotalExp; +import com.ycl.platform.domain.form.VideoExportForm; import com.ycl.platform.domain.query.DashboardQuery; import com.ycl.platform.domain.query.DataCenterQuery; import com.ycl.platform.domain.query.HomeQuery; +import com.ycl.platform.domain.result.BaseResult; import com.ycl.platform.domain.result.HK.FaceDeviceInspectionResult; import com.ycl.platform.domain.result.HK.FaceDeviceSamplingResult; import com.ycl.platform.domain.result.HK.VehicleDeviceInspectionResult; import com.ycl.platform.domain.result.HK.VehicleDeviceSamplingResult; +import com.ycl.platform.domain.result.SYS.TMonitorResult; import com.ycl.platform.domain.result.UY.MonitorQualifyResult; import com.ycl.platform.domain.result.UY.OsdCheckResult; import com.ycl.platform.domain.result.UY.RecordMetaDSumResult; import com.ycl.platform.domain.vo.TMonitorVO; import com.ycl.platform.domain.vo.WorkOrderVO; +import com.ycl.platform.domain.vo.home.BaseHomeVO; +import com.ycl.platform.domain.vo.home.HomeCarVO; +import com.ycl.platform.domain.vo.home.HomeFaceVO; +import com.ycl.platform.domain.vo.home.HomeVideoVO; import com.ycl.platform.domain.vo.screen.MonitorRateVO; import com.ycl.platform.domain.vo.screen.MonitorTotalVO; import com.ycl.platform.mapper.TMonitorMapper; import com.ycl.platform.mapper.WorkOrderMapper; import com.ycl.platform.service.ITMonitorService; import com.ycl.system.Result; +import com.ycl.system.entity.SysDictData; +import com.ycl.system.mapper.SysConfigMapper; +import com.ycl.system.mapper.SysDictDataMapper; import com.ycl.system.page.PageUtil; import com.ycl.system.service.ISysConfigService; import com.ycl.utils.DateUtils; import com.ycl.utils.StringUtils; +import constant.ApiConstants; +import constant.CheckConstants; import enumeration.general.AreaDeptEnum; +import jakarta.servlet.http.HttpServletResponse; +import lombok.SneakyThrows; import org.apache.commons.lang3.ObjectUtils; +import org.bson.Document; +import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.mongodb.core.MongoTemplate; import org.springframework.data.mongodb.core.query.Criteria; import org.springframework.data.mongodb.core.query.Query; import org.springframework.stereotype.Service; import org.springframework.util.CollectionUtils; +import pojo.ExcelExp; +import utils.poi.ExcelUtilManySheet; +import java.io.IOException; +import java.lang.reflect.Field; +import java.lang.reflect.InvocationTargetException; +import java.math.BigDecimal; +import java.text.DecimalFormat; +import java.text.ParseException; +import java.text.SimpleDateFormat; import java.time.LocalDate; +import java.time.YearMonth; +import java.time.ZoneId; +import java.time.format.DateTimeFormatter; +import java.time.temporal.TemporalAdjusters; import java.util.*; import java.util.stream.Collectors; @@ -55,6 +89,8 @@ private MongoTemplate mongoTemplate; @Autowired private WorkOrderMapper workOrderMapper; + @Autowired + private SysDictDataMapper dictDataMapper; /** * 鏌ヨ璁惧璧勪骇 @@ -111,9 +147,7 @@ //璁惧缂栧彿 List<String> numbers = monitors.stream().map(TMonitorVO::getSerialNumber).collect(Collectors.toList()); Query query = new Query(); - //TODO:鏈湴娴嬭瘯 - // Date now = new Date() - Date now = DateUtils.getDay(2024, 7, 13); + Date now = new Date(); query.addCriteria(Criteria.where("no").in(numbers) .and("mongoCreateTime").gte(DateUtils.getDayStart(now)).lt(DateUtils.getDayEnd(now)) ); @@ -342,10 +376,10 @@ total.put("title", "璁惧鎬绘暟"); Map<String, Object> normal = new HashMap<>(); normal.put("value", vo.getNormalNum()); - normal.put("title", "璁惧姝e父鏁�"); + normal.put("title", "姝e父鏁�"); Map<String, Object> error = new HashMap<>(); error.put("value", vo.getErrorNum()); - error.put("title", "璁惧寮傚父鏁�"); + error.put("title", "寮傚父鏁�"); list.add(total); list.add(normal); list.add(error); @@ -356,7 +390,6 @@ @Override public List<MonitorRateVO> monitorRate(DashboardQuery dashboardQuery) { - //TODO:鏂板dept AreaCode瀛楁 return baseMapper.monitorRate(dashboardQuery); } @@ -367,4 +400,666 @@ baseMapper.assetManagement(page, query); return Result.ok().data(page.getRecords()).total(page.getTotal()); } + + /** + * 瀵煎嚭鎬婚噺鏁版嵁 + */ + @Override + public void exportVideoTotal(HttpServletResponse response, VideoExportForm exportForm) throws IOException { + List<ExcelExp> mysheet = new ArrayList<>(); + exportForm.setCameraFunType(Integer.valueOf(CheckConstants.Rule_Category_Video + "")); + VideoExportForm.convertTags(exportForm); + List<TMonitorResult> tMonitorResults = tMonitorMapper.selectMonitorResult(exportForm); + List<String> deviceIds = tMonitorResults.stream().map(BaseResult::getNo).collect(Collectors.toList()); + Query query = getQuery(deviceIds, exportForm.getMonth()); + //鏈堜唤姣忔棩鍦ㄧ嚎鏁版嵁 + List<TMonitorResult> onlineResult = mongoTemplate.find(query, TMonitorResult.class); + //鏈堜唤姣忔棩褰曞儚鏁版嵁 + List<RecordMetaDSumResult> recordResult = mongoTemplate.find(query, RecordMetaDSumResult.class); + DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd"); + String[] weeks = {"鏄熸湡涓�", "鏄熸湡浜�", "鏄熸湡涓�", "鏄熸湡鍥�", "鏄熸湡浜�", "鏄熸湡鍏�", "鏄熸湡鏃�"}; + // 鍒涘缓涓�涓狹ap鏉ュ瓨鍌ㄦ瘡澶╃殑绱姞鏁版嵁 + Map<String, VideoTotalExp> totalMap = new HashMap<>(); + //涓�涓儴闂ㄤ竴涓猻heet + for (Integer deptId : exportForm.getDeptIds()) { + //浠庢暟鎹簱闆嗗悎绛涢�夐儴闂ㄦ暟鎹� + List<String> ids = tMonitorResults.stream().filter(tMonitorResult -> deptId.equals(tMonitorResult.getDeptId())).map(BaseResult::getNo).collect(Collectors.toList()); + if (CollectionUtils.isEmpty(ids)) continue; + //绛涢�夐儴闂ㄦ暟鎹� + List<TMonitorResult> onlineList = onlineResult.stream().filter(tMonitorResult -> ids.contains(tMonitorResult.getNo())).collect(Collectors.toList()); + List<RecordMetaDSumResult> recordList = recordResult.stream().filter(result -> ids.contains(result.getNo())).collect(Collectors.toList()); + List<VideoTotalExp> videoTotalExps = new ArrayList<>(); + for (int i = 0; i < 31; i++) { + String date = exportForm.getMonth(); + date += "-" + (i < 9 ? "0" + (i + 1) : (i + 1)); + //鎬婚噺 + VideoTotalExp totalExp = totalMap.computeIfAbsent(date, k -> new VideoTotalExp()); + LocalDate parseTime = LocalDate.parse(date, formatter); + //鑾峰彇鏄熸湡鍑� + String week = weeks[parseTime.getDayOfWeek().getValue() - 1]; + VideoTotalExp videoExp = new VideoTotalExp(); + videoExp.setDate(date); + videoExp.setWeek(week); + //璁剧疆鐐逛綅鍦ㄧ嚎鎬婚噺 + List<TMonitorResult> onlines = onlineList.stream().filter(tMonitorResult -> tMonitorResult.getMongoCreateTime().minusDays(1).equals(parseTime)).collect(Collectors.toList()); + if (!CollectionUtils.isEmpty(onlines)) { + videoExp.setTotal(onlines.size()); + videoExp.setOnline(Integer.valueOf(onlines.stream() + .filter(TMonitorResult::getOnline) + .count() + "")); + videoExp.setOffline(videoExp.getTotal() - videoExp.getOnline()); + } + //璁剧疆瀛樺偍鎯呭喌 + List<RecordMetaDSumResult> records = recordList.stream().filter(record -> record.getMongoCreateTime().minusDays(1).equals(parseTime)).collect(Collectors.toList()); + if (!CollectionUtils.isEmpty(records)) { + videoExp.setNoStore(Integer.valueOf(records.stream() + .filter(record -> ApiConstants.UY_RecordStatus_Abnormal.equals(record.getRecordStatus())) + .count() + "")); + videoExp.setPartStore(Integer.valueOf(records.stream() + .filter(record -> ApiConstants.UY_RecordStatus_Interval.equals(record.getRecordStatus())) + .count() + "")); + } + videoTotalExps.add(videoExp); + //绱姞浣滀负鍏ㄩ噺琛� + totalExp.setDate(date); + totalExp.setWeek(week); + totalExp.setTotal((totalExp.getTotal() == null ? 0 : totalExp.getTotal()) + (videoExp.getTotal() == null ? 0 : videoExp.getTotal())); + totalExp.setOnline((totalExp.getOnline() == null ? 0 : totalExp.getOnline()) + (videoExp.getOnline() == null ? 0 : videoExp.getOnline())); + totalExp.setOffline((totalExp.getOffline() == null ? 0 : totalExp.getOffline()) + (videoExp.getOffline() == null ? 0 : videoExp.getOffline())); + totalExp.setNoStore((totalExp.getNoStore() == null ? 0 : totalExp.getNoStore()) + (videoExp.getNoStore() == null ? 0 : videoExp.getNoStore())); + totalExp.setPartStore((totalExp.getPartStore() == null ? 0 : totalExp.getPartStore()) + (videoExp.getPartStore() == null ? 0 : videoExp.getPartStore())); + totalMap.put(date, totalExp); + } + AreaDeptEnum areaDeptEnum = AreaDeptEnum.fromDept(deptId); + ExcelExp excelExp = new ExcelExp(areaDeptEnum == null ? "鏈煡" : areaDeptEnum.getName(), videoTotalExps, VideoTotalExp.class); + mysheet.add(excelExp); + } + //娣诲姞鍏ㄩ噺琛� + List<VideoTotalExp> totalExps = new ArrayList<>(totalMap.values()); + totalExps = totalExps.stream().sorted(Comparator.comparing(VideoTotalExp::getDate)).collect(Collectors.toList()); + ExcelExp excelExp = new ExcelExp("鍏ㄩ噺", totalExps, VideoTotalExp.class); + mysheet.add(excelExp); + //瀵煎嚭 + ExcelUtilManySheet<List<ExcelExp>> util = new ExcelUtilManySheet<>(mysheet); + util.exportExcelManySheet(response, mysheet); + } + + + /** + * 瀵煎嚭姣忔棩鍦ㄧ嚎鏁版嵁 + */ + @Override + public void exportVideoOnline(HttpServletResponse response, VideoExportForm exportForm) throws IOException, NoSuchFieldException, IllegalAccessException { + List<ExcelExp> mysheet = new ArrayList<>(); + exportForm.setCameraFunType(Integer.valueOf(CheckConstants.Rule_Category_Video + "")); + VideoExportForm.convertTags(exportForm); + List<TMonitorResult> tMonitorResults = tMonitorMapper.selectMonitorResult(exportForm); + List<String> deviceIds = tMonitorResults.stream().map(BaseResult::getNo).collect(Collectors.toList()); + Query query = getQuery(deviceIds, exportForm.getMonth()); + //鏈堜唤姣忔棩鍦ㄧ嚎鏁版嵁 + List<TMonitorResult> onlineResult = mongoTemplate.find(query, TMonitorResult.class); + //鍏ㄩ噺琛� + List<VideoDailyExp> totalExps = new ArrayList<>(); + for (Integer deptId : exportForm.getDeptIds()) { + List<VideoDailyExp> videoDailyExps = new ArrayList<>(); + //浠庢暟鎹簱闆嗗悎绛涢�夐儴闂ㄦ暟鎹� + List<TMonitorResult> monitors = tMonitorResults.stream().filter(tMonitorResult -> deptId.equals(tMonitorResult.getDeptId())).collect(Collectors.toList()); + if (CollectionUtils.isEmpty(monitors)) continue; + List<String> ids = monitors.stream().map(BaseResult::getNo).collect(Collectors.toList()); + //绛涢�塵ongo鍖哄幙鏁版嵁 + List<TMonitorResult> onlines = onlineResult.stream().filter(result -> ids.contains(result.getNo())).collect(Collectors.toList()); + AreaDeptEnum areaDeptEnum = AreaDeptEnum.fromDept(deptId); + for (TMonitorResult result : monitors) { + VideoDailyExp videoDailyExp = new VideoDailyExp(); + videoDailyExp.setSerialNumber(result.getNo()); + videoDailyExp.setDeviceName(result.getName()); + videoDailyExp.setArea(areaDeptEnum == null ? "鏈煡" : areaDeptEnum.getName()); + String tag = "" + (result.getProvinceTag() ? "鐪佸巺銆�" : "") + (result.getImportantTag() ? "閲嶇偣鐐逛綅銆�" : "") + (result.getImportantCommandImageTag() ? "閲嶇偣鎸囨尌鍥惧儚銆�" : "") + (result.getDeptTag() ? "閮ㄧ骇銆�" : ""); + // 鍒犻櫎瀛楃涓叉湯灏剧殑鈥溿�佲�� + if (tag.endsWith("銆�")) { + tag = tag.substring(0, tag.length() - 1); + } + videoDailyExp.setTag(tag); + setOnlineDaily(videoDailyExp, result, onlines); + videoDailyExps.add(videoDailyExp); + //鍏ㄩ噺琛� + totalExps.add(videoDailyExp); + } + ExcelExp excelExp = new ExcelExp(areaDeptEnum == null ? "鏈煡" : areaDeptEnum.getName(), videoDailyExps, VideoDailyExp.class); + mysheet.add(excelExp); + } + ExcelExp excelExp = new ExcelExp("鍏ㄩ噺", totalExps, VideoDailyExp.class); + mysheet.add(excelExp); + ExcelUtilManySheet<List<ExcelExp>> util = new ExcelUtilManySheet<>(mysheet); + util.exportExcelManySheet(response, mysheet); + } + + + /** + * 瀵煎嚭姣忔棩褰曞儚鎯呭喌鏁版嵁 + */ + @Override + public void exportVideoRecord(HttpServletResponse response, VideoExportForm exportForm) throws IOException, NoSuchFieldException, IllegalAccessException { + List<ExcelExp> mysheet = new ArrayList<>(); + exportForm.setCameraFunType(Integer.valueOf(CheckConstants.Rule_Category_Video + "")); + VideoExportForm.convertTags(exportForm); + List<TMonitorResult> tMonitorResults = tMonitorMapper.selectMonitorResult(exportForm); + List<String> deviceIds = tMonitorResults.stream().map(BaseResult::getNo).collect(Collectors.toList()); + Query query = getQuery(deviceIds, exportForm.getMonth()); + //鏈堜唤姣忔棩褰曞儚绾挎暟鎹� + List<RecordMetaDSumResult> recordResult = mongoTemplate.find(query, RecordMetaDSumResult.class); + //鍏ㄩ噺琛� + List<VideoDailyExp> totalExps = new ArrayList<>(); + for (Integer deptId : exportForm.getDeptIds()) { + List<VideoDailyExp> videoDailyExps = new ArrayList<>(); + //浠庢暟鎹簱闆嗗悎绛涢�夐儴闂ㄦ暟鎹� + List<TMonitorResult> monitors = tMonitorResults.stream().filter(tMonitorResult -> deptId.equals(tMonitorResult.getDeptId())).collect(Collectors.toList()); + if (CollectionUtils.isEmpty(monitors)) continue; + List<String> ids = monitors.stream().map(BaseResult::getNo).collect(Collectors.toList()); + //绛涢�塵ongo鍖哄幙鏁版嵁 + List<RecordMetaDSumResult> records = recordResult.stream().filter(result -> ids.contains(result.getNo())).collect(Collectors.toList()); + AreaDeptEnum areaDeptEnum = AreaDeptEnum.fromDept(deptId); + for (TMonitorResult result : monitors) { + VideoDailyExp videoDailyExp = new VideoDailyExp(); + videoDailyExp.setSerialNumber(result.getNo()); + videoDailyExp.setDeviceName(result.getName()); + videoDailyExp.setArea(areaDeptEnum == null ? "鏈煡" : areaDeptEnum.getName()); + String tag = "" + (result.getProvinceTag() ? "鐪佸巺銆�" : "") + (result.getImportantTag() ? "閲嶇偣鐐逛綅銆�" : "") + (result.getImportantCommandImageTag() ? "閲嶇偣鎸囨尌鍥惧儚銆�" : "") + (result.getDeptTag() ? "閮ㄧ骇銆�" : ""); + // 鍒犻櫎瀛楃涓叉湯灏剧殑鈥溿�佲�� + if (tag.endsWith("銆�")) { + tag = tag.substring(0, tag.length() - 1); + } + videoDailyExp.setTag(tag); + setRecordDaily(videoDailyExp, result, records); + //鍖哄幙琛� + videoDailyExps.add(videoDailyExp); + //鍏ㄩ噺琛� + totalExps.add(videoDailyExp); + } + ExcelExp excelExp = new ExcelExp(areaDeptEnum == null ? "鏈煡" : areaDeptEnum.getName(), videoDailyExps, VideoDailyExp.class); + mysheet.add(excelExp); + } + ExcelExp excelExp = new ExcelExp("鍏ㄩ噺", totalExps, VideoDailyExp.class); + mysheet.add(excelExp); + ExcelUtilManySheet<List<ExcelExp>> util = new ExcelUtilManySheet<>(mysheet); + util.exportExcelManySheet(response, mysheet); + } + + /** + * 瀵煎嚭姣忔棩褰曞儚缂哄け鏃堕暱 + */ + @Override + public void exportVideoLoseTime(HttpServletResponse response, VideoExportForm exportForm) throws NoSuchFieldException, IllegalAccessException, IOException { + List<ExcelExp> mysheet = new ArrayList<>(); + exportForm.setCameraFunType(Integer.valueOf(CheckConstants.Rule_Category_Video + "")); + VideoExportForm.convertTags(exportForm); + List<TMonitorResult> tMonitorResults = tMonitorMapper.selectMonitorResult(exportForm); + List<String> deviceIds = tMonitorResults.stream().map(BaseResult::getNo).collect(Collectors.toList()); + Query query = getQuery(deviceIds, exportForm.getMonth()); + //鏈堜唤姣忔棩褰曞儚绾挎暟鎹� + List<RecordMetaDSumResult> recordResult = mongoTemplate.find(query, RecordMetaDSumResult.class); + //鍏ㄩ噺琛� + List<VideoDailyExp> totalExps = new ArrayList<>(); + for (Integer deptId : exportForm.getDeptIds()) { + List<VideoDailyExp> videoDailyExps = new ArrayList<>(); + //浠庢暟鎹簱闆嗗悎绛涢�夐儴闂ㄦ暟鎹� + List<TMonitorResult> monitors = tMonitorResults.stream().filter(tMonitorResult -> deptId.equals(tMonitorResult.getDeptId())).collect(Collectors.toList()); + if (CollectionUtils.isEmpty(monitors)) continue; + List<String> ids = monitors.stream().map(BaseResult::getNo).collect(Collectors.toList()); + //绛涢�塵ongo鍖哄幙鏁版嵁 + List<RecordMetaDSumResult> records = recordResult.stream().filter(result -> ids.contains(result.getNo())).collect(Collectors.toList()); + AreaDeptEnum areaDeptEnum = AreaDeptEnum.fromDept(deptId); + for (TMonitorResult result : monitors) { + VideoDailyExp videoDailyExp = new VideoDailyExp(); + videoDailyExp.setSerialNumber(result.getNo()); + videoDailyExp.setDeviceName(result.getName()); + videoDailyExp.setArea(areaDeptEnum == null ? "鏈煡" : areaDeptEnum.getName()); + String tag = "" + (result.getProvinceTag() ? "鐪佸巺銆�" : "") + (result.getImportantTag() ? "閲嶇偣鐐逛綅銆�" : "") + (result.getImportantCommandImageTag() ? "閲嶇偣鎸囨尌鍥惧儚銆�" : "") + (result.getDeptTag() ? "閮ㄧ骇銆�" : ""); + // 鍒犻櫎瀛楃涓叉湯灏剧殑鈥溿�佲�� + if (tag.endsWith("銆�")) { + tag = tag.substring(0, tag.length() - 1); + } + videoDailyExp.setTag(tag); + setLoseDaily(videoDailyExp, result, records); + videoDailyExps.add(videoDailyExp); + //鍏ㄩ噺琛� + totalExps.add(videoDailyExp); + } + ExcelExp excelExp = new ExcelExp(areaDeptEnum == null ? "鏈煡" : areaDeptEnum.getName(), videoDailyExps, VideoDailyExp.class); + mysheet.add(excelExp); + } + ExcelExp excelExp = new ExcelExp("鍏ㄩ噺", totalExps, VideoDailyExp.class); + mysheet.add(excelExp); + ExcelUtilManySheet<List<ExcelExp>> util = new ExcelUtilManySheet<>(mysheet); + util.exportExcelManySheet(response, mysheet); + } + + //棣栭〉瑙嗛鎶ヨ〃 + @Override + public Map<String, Object> videoHome(HomeQuery monitorQuery) throws ParseException, InvocationTargetException, NoSuchMethodException, InstantiationException, IllegalAccessException { + List<HomeVideoVO> results = new ArrayList<>(); + String month = monitorQuery.getDate(); + if (StringUtils.isEmpty(month)) { + //濡傛灉涓虹┖鏌ユ湰鏈堢殑鏁版嵁 + SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM"); + month = simpleDateFormat.format(new Date()); + } + // 鍒涘缓涓�涓猄impleDateFormat瀵硅薄鏉ヨВ鏋愭棩鏈熷瓧绗︿覆 + SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM"); + Date date = sdf.parse(month); + // 鍒涘缓涓�涓狢alendar瀵硅薄骞惰缃椂闂翠负瑙f瀽鍑虹殑Date + Calendar calendar = Calendar.getInstance(); + calendar.setTime(date); + // 璁剧疆Calendar涓烘湀浠界殑绗竴澶� + calendar.set(Calendar.DAY_OF_MONTH, 1); + // 鑾峰彇鏈堜唤绗竴澶╃殑Date + Date startDate = calendar.getTime(); + // 璁剧疆Calendar涓烘湀浠界殑鏈�鍚庝竴澶╋紙閫氳繃澧炲姞涓�涓湀浠界劧鍚庡噺鍘讳竴澶╋級 + calendar.add(Calendar.MONTH, 1); + calendar.add(Calendar.DAY_OF_MONTH, -1); + // 鑾峰彇鏈堜唤鏈�鍚庝竴澶╃殑Date + Date endDate = calendar.getTime(); + + //mongo鏌ュ綍鍍忕姸鎬� + MongoDatabase database = mongoTemplate.getDb(); + MongoCollection<Document> collection = database.getCollection("uy_record_meta_d_sum"); + Integer examineTag = monitorQuery.getExamineTag(); + Document matchConditions = new Document("mongoCreateTime", new Document("$gte", startDate).append("$lte", endDate)); + // 鏍规嵁examineTag鐨勫�煎姩鎬佹坊鍔犻澶栫殑鏉′欢 + if (examineTag != null && examineTag.equals(1)) { + matchConditions.append("provinceTag", true); + } else if (examineTag != null && examineTag.equals(2)) { + matchConditions.append("deptTag", true); + } + // 鏋勫缓鑱氬悎绠¢亾 + List<Document> pipeline = Arrays.asList( + new Document("$match", matchConditions), + new Document("$group", new Document("_id", "$mongoCreateTime") + .append("normalCount", new Document("$sum", + new Document("$cond", Arrays.asList( + new Document("$eq", Arrays.asList("$recordStatus", 1)), + 1, + 0 + )) + )) + .append("loseCount", new Document("$sum", + new Document("$cond", Arrays.asList( + new Document("$eq", Arrays.asList("$recordStatus", -1)), + 1, + 0 + )) + )) + ) + ); + // 鎵ц鑱氬悎鏌ヨ骞惰幏鍙栫粨鏋� + AggregateIterable<Document> result = collection.aggregate(pipeline); + for (Document doc : result) { + HomeVideoVO homeVideoVO = new HomeVideoVO(); + homeVideoVO.setCreateDate(doc.getDate("_id")); + homeVideoVO.setIntegrityNum(doc.getInteger("normalCount")); + homeVideoVO.setLoseNum(doc.getInteger("loseCount")); + results.add(homeVideoVO); + } + + //mongo鏌ョ偣浣嶅湪绾� + MongoCollection<Document> onlineCollection = database.getCollection("t_monitor_online"); + // 鏋勫缓鍩烘湰鐨�$match鏉′欢 + List<Document> onlineMatch = new ArrayList<>(); + onlineMatch.add(new Document("mongoCreateTime", new Document("$gte", startDate).append("$lte", endDate))); + onlineMatch.add(new Document("monitorType", new Document("$regex", "1"))); + if (examineTag != null && examineTag.equals(1)) { + onlineMatch.add(new Document("provinceTag", true)); + } else if (examineTag != null && examineTag.equals(2)) { + onlineMatch.add(new Document("deptTag", true)); + } + + // 鏋勫缓鑱氬悎绠¢亾 + List<Document> onlinePipeline = Arrays.asList( + new Document("$match", new Document("$and", onlineMatch)), + new Document("$group", new Document("_id", "$mongoCreateTime") + .append("onlineCount", new Document("$sum", + new Document("$cond", Arrays.asList( + new Document("$eq", Arrays.asList("$online", Boolean.TRUE)), + 1, + 0 + )) + )) + ) + ); + // 鎵ц鑱氬悎鏌ヨ骞惰幏鍙栫粨鏋� + AggregateIterable<Document> onlineResult = onlineCollection.aggregate(onlinePipeline); + for (Document doc : onlineResult) { + HomeVideoVO vo = findOrCreateVO(doc, results, HomeVideoVO.class); + vo.setOnline(doc.getInteger("onlineCount")); + } + results = results.stream().sorted(Comparator.comparing(BaseHomeVO::getCreateDate)).collect(Collectors.toList()); + Map<String, Object> resultMap = new HashMap<>(); + resultMap.put("list", results); + //浠庡瓧鍏歌幏鍙栧熀鍑嗙嚎 + List<SysDictData> baseLines = dictDataMapper.selectDictDataByType("home_baseLine"); + String condition; + if (examineTag != null && examineTag == 1) { + condition = "video_province_baseLine"; + } else if (examineTag != null && examineTag == 2) { + condition = "video_dept_baseLine"; + } else { + condition = "video_all_baseLine"; + } + Optional<SysDictData> first = baseLines.stream().filter(sysDictData -> condition.equals(sysDictData.getDictLabel())).findFirst(); + if (first.isPresent()) { + SysDictData sysDictData = first.get(); + resultMap.put("baseLine", Integer.valueOf(sysDictData.getDictValue())); + } + return resultMap; + } + + + //棣栭〉杞﹁締鎶ヨ〃 + @Override + public Map<String, Object> carHome(HomeQuery monitorQuery) throws ParseException, InvocationTargetException, NoSuchMethodException, InstantiationException, IllegalAccessException { + List<HomeCarVO> results = new ArrayList<>(); + String month = monitorQuery.getDate(); + if (StringUtils.isEmpty(month)) { + //濡傛灉涓虹┖鏌ユ湰鏈堢殑鏁版嵁 + SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM"); + month = simpleDateFormat.format(new Date()); + } + // 鍒涘缓涓�涓猄impleDateFormat瀵硅薄鏉ヨВ鏋愭棩鏈熷瓧绗︿覆 + SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM"); + Date date = sdf.parse(month); + // 鍒涘缓涓�涓狢alendar瀵硅薄骞惰缃椂闂翠负瑙f瀽鍑虹殑Date + Calendar calendar = Calendar.getInstance(); + calendar.setTime(date); + // 璁剧疆Calendar涓烘湀浠界殑绗竴澶� + calendar.set(Calendar.DAY_OF_MONTH, 1); + // 鑾峰彇鏈堜唤绗竴澶╃殑Date + Date startDate = calendar.getTime(); + // 璁剧疆Calendar涓烘湀浠界殑鏈�鍚庝竴澶╋紙閫氳繃澧炲姞涓�涓湀浠界劧鍚庡噺鍘讳竴澶╋級 + calendar.add(Calendar.MONTH, 1); + calendar.add(Calendar.DAY_OF_MONTH, -1); + // 鑾峰彇鏈堜唤鏈�鍚庝竴澶╃殑Date + Date endDate = calendar.getTime(); + //mongo鏌ユ姄鎷嶉噺 + MongoDatabase database = mongoTemplate.getDb(); + MongoCollection<Document> collection = database.getCollection("hk_snapshot_data_monitor"); + Integer examineTag = monitorQuery.getExamineTag(); + // 鏋勫缓鍩烘湰鐨�$match鏉′欢 + List<Document> matchConditions = new ArrayList<>(); + matchConditions.add(new Document("mongoCreateTime", new Document("$gte", startDate).append("$lte", endDate))); + matchConditions.add(new Document("dataType", new Document("$eq", ApiConstants.HK_DataType_CAR))); + if (examineTag != null && examineTag.equals(1)) { + matchConditions.add(new Document("provinceTag", true)); + } else if (examineTag != null && examineTag.equals(2)) { + matchConditions.add(new Document("deptTag", true)); + } + // 鏋勫缓鑱氬悎绠¢亾 + List<Document> pipeline = Arrays.asList( + new Document("$match", new Document("$and", matchConditions)), + new Document("$group", new Document("_id", "$mongoCreateTime") + .append("dataCount", new Document("$sum", "$dataCount")) + ) + ); + + // 鎵ц鑱氬悎鏌ヨ骞惰幏鍙栫粨鏋� + AggregateIterable<Document> result = collection.aggregate(pipeline); + for (Document doc : result) { + HomeCarVO homecarVO = new HomeCarVO(); + homecarVO.setCreateDate(doc.getDate("_id")); + homecarVO.setSnapCount(doc.getInteger("dataCount")); + results.add(homecarVO); + } + + //mongo鏌ョ偣浣嶅湪绾� + MongoCollection<Document> onlineCollection = database.getCollection("t_monitor_online"); + // 鏋勫缓鍩烘湰鐨�$match鏉′欢 + List<Document> onlineMatch = new ArrayList<>(); + onlineMatch.add(new Document("mongoCreateTime", new Document("$gte", startDate).append("$lte", endDate))); + onlineMatch.add(new Document("monitorType", new Document("$regex", "2"))); + if (examineTag != null && examineTag.equals(1)) { + onlineMatch.add(new Document("provinceTag", true)); + } else if (examineTag != null && examineTag.equals(2)) { + onlineMatch.add(new Document("deptTag", true)); + } + // 鏋勫缓鑱氬悎绠¢亾 + List<Document> onlinePipeline = Arrays.asList( + new Document("$match", new Document("$and", onlineMatch)), + new Document("$group", new Document("_id", "$mongoCreateTime") + .append("onlineCount", new Document("$sum", + new Document("$cond", Arrays.asList( + new Document("$eq", Arrays.asList("$online", Boolean.TRUE)), + 1, + 0 + )) + )) + ) + ); + // 鎵ц鑱氬悎鏌ヨ骞惰幏鍙栫粨鏋� + AggregateIterable<Document> onlineResult = onlineCollection.aggregate(onlinePipeline); + for (Document doc : onlineResult) { + HomeCarVO vo = findOrCreateVO(doc, results, HomeCarVO.class); + vo.setOnline(doc.getInteger("onlineCount")); + } + Map<String, Object> resultMap = new HashMap<>(); + //鎸夋椂闂存帓搴� + results = results.stream().sorted(Comparator.comparing(BaseHomeVO::getCreateDate)).collect(Collectors.toList()); + int snapCount = 0; + for (HomeCarVO vo : results) { + if (vo.getSnapCount() != null) { + snapCount += vo.getSnapCount(); + } + vo.setSnapCount(snapCount); + } + resultMap.put("list", results); + //浠庡瓧鍏歌幏鍙栧熀鍑嗙嚎 + List<SysDictData> baseLines = dictDataMapper.selectDictDataByType("home_baseLine"); + String condition; + if (examineTag != null && examineTag == 1) { + condition = "car_province_baseLine"; + } else if (examineTag != null && examineTag == 2) { + condition = "car_dept_baseLine"; + } else { + condition = "car_all_baseLine"; + } + + Optional<SysDictData> first = baseLines.stream().filter(sysDictData -> condition.equals(sysDictData.getDictLabel())).findFirst(); + if (first.isPresent()) { + SysDictData sysDictData = first.get(); + resultMap.put("baseLine", Integer.valueOf(sysDictData.getDictValue())); + } + return resultMap; + } + + //棣栭〉浜鸿劯鎶ヨ〃 + @Override + public Map<String, Object> faceHome(HomeQuery monitorQuery) throws ParseException, InvocationTargetException, NoSuchMethodException, InstantiationException, IllegalAccessException { + List<HomeFaceVO> results = new ArrayList<>(); + String month = monitorQuery.getDate(); + if (StringUtils.isEmpty(month)) { + //濡傛灉涓虹┖鏌ユ湰鏈堢殑鏁版嵁 + SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM"); + month = simpleDateFormat.format(new Date()); + } + // 鍒涘缓涓�涓猄impleDateFormat瀵硅薄鏉ヨВ鏋愭棩鏈熷瓧绗︿覆 + SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM"); + Date date = sdf.parse(month); + // 鍒涘缓涓�涓狢alendar瀵硅薄骞惰缃椂闂翠负瑙f瀽鍑虹殑Date + Calendar calendar = Calendar.getInstance(); + calendar.setTime(date); + // 璁剧疆Calendar涓烘湀浠界殑绗竴澶� + calendar.set(Calendar.DAY_OF_MONTH, 1); + // 鑾峰彇鏈堜唤绗竴澶╃殑Date + Date startDate = calendar.getTime(); + // 璁剧疆Calendar涓烘湀浠界殑鏈�鍚庝竴澶╋紙閫氳繃澧炲姞涓�涓湀浠界劧鍚庡噺鍘讳竴澶╋級 + calendar.add(Calendar.MONTH, 1); + calendar.add(Calendar.DAY_OF_MONTH, -1); + // 鑾峰彇鏈堜唤鏈�鍚庝竴澶╃殑Date + Date endDate = calendar.getTime(); + //mongo鏌ユ姄鎷嶉噺 + MongoDatabase database = mongoTemplate.getDb(); + MongoCollection<Document> collection = database.getCollection("hk_snapshot_data_monitor"); + Integer examineTag = monitorQuery.getExamineTag(); + // 鏋勫缓鍩烘湰鐨�$match鏉′欢 + List<Document> matchConditions = new ArrayList<>(); + matchConditions.add(new Document("mongoCreateTime", new Document("$gte", startDate).append("$lte", endDate))); + matchConditions.add(new Document("dataType", new Document("$eq", ApiConstants.HK_DataType_FACE))); + if (examineTag != null && examineTag.equals(1)) { + matchConditions.add(new Document("provinceTag", true)); + } else if (examineTag != null && examineTag.equals(2)) { + matchConditions.add(new Document("deptTag", true)); + } + // 鏋勫缓鑱氬悎绠¢亾 + List<Document> pipeline = Arrays.asList( + new Document("$match", new Document("$and", matchConditions)), + new Document("$group", new Document("_id", "$mongoCreateTime") + .append("dataCount", new Document("$sum", "$dataCount")) + ) + ); + + // 鎵ц鑱氬悎鏌ヨ骞惰幏鍙栫粨鏋� + AggregateIterable<Document> result = collection.aggregate(pipeline); + for (Document doc : result) { + HomeFaceVO homefaceVO = new HomeFaceVO(); + homefaceVO.setCreateDate(doc.getDate("_id")); + homefaceVO.setSnapCount(doc.getInteger("dataCount")); + results.add(homefaceVO); + } + + //mongo鏌ョ偣浣嶅湪绾� + MongoCollection<Document> onlineCollection = database.getCollection("t_monitor_online"); + // 鏋勫缓鍩烘湰鐨�$match鏉′欢 + List<Document> onlineMatch = new ArrayList<>(); + onlineMatch.add(new Document("mongoCreateTime", new Document("$gte", startDate).append("$lte", endDate))); + onlineMatch.add(new Document("monitorType", new Document("$regex", "3"))); + if (examineTag != null && examineTag.equals(1)) { + onlineMatch.add(new Document("provinceTag", true)); + } else if (examineTag != null && examineTag.equals(2)) { + onlineMatch.add(new Document("deptTag", true)); + } + // 鏋勫缓鑱氬悎绠¢亾 + List<Document> onlinePipeline = Arrays.asList( + new Document("$match", new Document("$and", onlineMatch)), + new Document("$group", new Document("_id", "$mongoCreateTime") + .append("onlineCount", new Document("$sum", + new Document("$cond", Arrays.asList( + new Document("$eq", Arrays.asList("$online", Boolean.TRUE)), + 1, + 0 + )) + )) + ) + ); + // 鎵ц鑱氬悎鏌ヨ骞惰幏鍙栫粨鏋� + AggregateIterable<Document> onlineResult = onlineCollection.aggregate(onlinePipeline); + for (Document doc : onlineResult) { + HomeFaceVO vo = findOrCreateVO(doc, results, HomeFaceVO.class); + vo.setOnline(doc.getInteger("onlineCount")); + } + //鎸夋椂闂存帓搴� + results = results.stream().sorted(Comparator.comparing(BaseHomeVO::getCreateDate)).collect(Collectors.toList()); + int snapCount = 0; + for (HomeFaceVO vo : results) { + if (vo.getSnapCount() != null) { + snapCount += vo.getSnapCount(); + } + vo.setSnapCount(snapCount); + } + Map<String, Object> resultMap = new HashMap<>(); + resultMap.put("list", results); + //浠庡瓧鍏歌幏鍙栧熀鍑嗙嚎 + List<SysDictData> baseLines = dictDataMapper.selectDictDataByType("home_baseLine"); + String condition; + if (examineTag != null && examineTag == 1) { + condition = "face_province_baseLine"; + } else if (examineTag != null && examineTag == 2) { + condition = "face_dept_baseLine"; + } else { + condition = "face_all_baseLine"; + } + Optional<SysDictData> first = baseLines.stream().filter(sysDictData -> condition.equals(sysDictData.getDictLabel())).findFirst(); + if (first.isPresent()) { + SysDictData sysDictData = first.get(); + resultMap.put("baseLine", Integer.valueOf(sysDictData.getDictValue())); + } + return resultMap; + } + + private <T extends BaseHomeVO> T findOrCreateVO(Document doc, List<T> results, Class<T> clazz) throws NoSuchMethodException, InvocationTargetException, InstantiationException, IllegalAccessException { + Date createDate = doc.getDate("_id"); + for (T vo : results) { + if (vo.getCreateDate().equals(createDate)) { + return vo; + } + } + // 濡傛灉娌℃湁鎵惧埌鍖归厤椤癸紝鍒欏垱寤轰竴涓柊鐨刅O + T vo = clazz.getDeclaredConstructor().newInstance(); + vo.setCreateDate(createDate); + results.add(vo); + return vo; + } + + private Query getQuery(List<String> deviceIds, String month) { + // 灏嗗勾鏈堝瓧绗︿覆瑙f瀽涓篩earMonth瀵硅薄 + YearMonth yearMonth = YearMonth.parse(month); + // 鑾峰彇褰撴湀鐨勭涓�澶� + LocalDate start = yearMonth.atDay(1); + // 鑾峰彇涓嬩釜鏈堢殑绗竴澶╋紙閫氳繃鍔犱笂1涓湀骞惰缃棩涓�1锛� + YearMonth nextMonth = yearMonth.plusMonths(1); + LocalDate end = nextMonth.atDay(1); + //鑾峰彇杩欎釜鏈堜唤鐨勯儴闂ㄦ暟鎹� + Query query = new Query(Criteria.where("mongoCreateTime").gte(start).lt(end)); + query.addCriteria(Criteria.where("no").in(deviceIds)); + return query; + } + + //璁剧疆姣忔棩鍦ㄧ嚎鏁版嵁 + private void setOnlineDaily(VideoDailyExp videoDailyExp, TMonitorResult result, List<TMonitorResult> onlines) throws NoSuchFieldException, IllegalAccessException { + //涓�涓澶囧綋鏈堝湪绾挎儏鍐� + List<TMonitorResult> onlineResult = onlines.stream().filter(online -> online.getNo().equals(result.getNo())).collect(Collectors.toList()); + for (TMonitorResult monitorResult : onlineResult) { + int dayOfMonth = monitorResult.getMongoCreateTime().getDayOfMonth(); + String online = ""; + online += monitorResult.getOnline() ? "鍦ㄧ嚎" : "绂荤嚎"; + //鍙嶅皠璧嬪�硷紝瀛楁缁熶竴瀹氫箟涓篸ay+1锛�2锛�3... + Field field = videoDailyExp.getClass().getDeclaredField("day" + dayOfMonth); + field.setAccessible(true); + field.set(videoDailyExp, online); + } + } + + //璁剧疆姣忔棩褰曞儚鏁版嵁 + private void setRecordDaily(VideoDailyExp videoDailyExp, TMonitorResult result, List<RecordMetaDSumResult> records) throws NoSuchFieldException, IllegalAccessException { + //涓�涓澶囧綋鏈堝湪绾挎儏鍐� + List<RecordMetaDSumResult> recordResults = records.stream().filter(online -> online.getNo().equals(result.getNo())).collect(Collectors.toList()); + for (RecordMetaDSumResult recordResult : recordResults) { + int dayOfMonth = recordResult.getMongoCreateTime().getDayOfMonth(); + Integer status = recordResult.getRecordStatus(); + String text = ""; + if (ApiConstants.UY_RecordStatus_Interval.equals(status)) { + text += "闂存瓏"; + } else if (ApiConstants.UY_RecordStatus_Abnormal.equals(status)) { + text += "缂哄け"; + } else if (ApiConstants.UY_RecordStatus_Integrity.equals(status)) { + text += "瀹屾暣"; + } + //鍙嶅皠璧嬪�硷紝瀛楁缁熶竴瀹氫箟涓篸ay+1锛�2锛�3... + Field field = videoDailyExp.getClass().getDeclaredField("day" + dayOfMonth); + field.setAccessible(true); + field.set(videoDailyExp, text); + } + } + + //璁剧疆姣忔棩褰曞儚缂哄け鏃堕暱鏁版嵁 + private void setLoseDaily(VideoDailyExp videoDailyExp, TMonitorResult result, List<RecordMetaDSumResult> records) throws NoSuchFieldException, IllegalAccessException { + //涓�涓澶囧綋鏈堝湪绾挎儏鍐� + List<RecordMetaDSumResult> recordResults = records.stream().filter(online -> online.getNo().equals(result.getNo())).collect(Collectors.toList()); + for (RecordMetaDSumResult recordResult : recordResults) { + int dayOfMonth = recordResult.getMongoCreateTime().getDayOfMonth(); + //鍙嶅皠璧嬪�硷紝瀛楁缁熶竴瀹氫箟涓篸ay+1锛�2锛�3... + Field field = videoDailyExp.getClass().getDeclaredField("day" + dayOfMonth); + field.setAccessible(true); + //闃叉杞崲涓虹瀛﹁鏁版硶 + BigDecimal bigDecimal = BigDecimal.valueOf(recordResult.getMissDuration() == null ? 0 : recordResult.getMissDuration()); + field.set(videoDailyExp, bigDecimal.toString()); + } + } } -- Gitblit v1.8.0