From 9d30f3aba92b1fe90eaecd486113f544f0f18b7c Mon Sep 17 00:00:00 2001 From: xiangpei <xiangpei@timesnew.cn> Date: 星期五, 16 八月 2024 16:41:11 +0800 Subject: [PATCH] 资产管理动态字段 --- ycl-server/src/main/java/com/ycl/task/MonitorTask.java | 106 ++++++++++++++++++++++++++++++++++++---------------- 1 files changed, 73 insertions(+), 33 deletions(-) diff --git a/ycl-server/src/main/java/com/ycl/task/MonitorTask.java b/ycl-server/src/main/java/com/ycl/task/MonitorTask.java index 8cc0d10..9dc6986 100644 --- a/ycl-server/src/main/java/com/ycl/task/MonitorTask.java +++ b/ycl-server/src/main/java/com/ycl/task/MonitorTask.java @@ -6,13 +6,16 @@ import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.ycl.platform.domain.entity.TMonitor; import com.ycl.platform.domain.entity.YwPoint; +import com.ycl.platform.domain.result.UY.MonitorQualifyResult; import com.ycl.platform.domain.result.UY.OneMachineFileResult; import com.ycl.platform.domain.vo.TMonitorVO; +import com.ycl.platform.mapper.TMonitorMapper; import com.ycl.platform.service.ITMonitorService; import com.ycl.platform.service.YwPointService; import com.ycl.system.entity.SysDictData; import com.ycl.system.service.ISysDictDataService; import com.ycl.utils.DateUtils; +import com.ycl.utils.StringUtils; import constant.RedisConstant; import enumeration.general.AreaDeptEnum; import enumeration.general.PointStatus; @@ -23,6 +26,7 @@ import org.springframework.data.mongodb.core.query.Query; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.stereotype.Component; +import org.springframework.transaction.annotation.Transactional; import org.springframework.util.CollectionUtils; import java.util.*; @@ -40,6 +44,8 @@ @Autowired private ITMonitorService monitorService; @Autowired + private TMonitorMapper monitorMapper; + @Autowired private ISysDictDataService dictDataService; @Autowired private YwPointService ywPointService; @@ -47,11 +53,23 @@ private RedisTemplate redisTemplate; //鍚屾mongodb涓�鏈轰竴妗e埌鏁版嵁搴� + @Transactional public void synchronize() { - Query query = new Query(Criteria.where("mongoCreateTime").gte(DateUtils.getDayStart(new Date())).lt(DateUtils.getDayEnd(new Date()))); - List<OneMachineFileResult> oneMachineFileResults = mongoTemplate.find(query, OneMachineFileResult.class); + // 鑾峰彇Calendar瀹炰緥锛岄粯璁や娇鐢ㄥ綋鍓嶆椂鍖哄拰璇█鐜 + Calendar calendar = Calendar.getInstance(); + // 娓呴櫎Calendar涓殑鎵�鏈夊瓧娈靛�硷紝浠ラ伩鍏嶅畠浠褰撳墠鏃ユ湡鏃堕棿鏈夊奖鍝� + calendar.clear(); + // 璁剧疆骞翠唤銆佹湀浠斤紙娉ㄦ剰锛氭湀浠芥槸浠�0寮�濮嬬殑锛屾墍浠�8鏈堟槸7锛夈�佹棩鏈� + calendar.set(Calendar.YEAR, 2024); + calendar.set(Calendar.MONTH, Calendar.AUGUST); + calendar.set(Calendar.DAY_OF_MONTH, 13); + // Calendar.getTime()鏂规硶杩斿洖涓�涓〃绀烘Calendar鏃堕棿鍊肩殑Date瀵硅薄 + Date date = calendar.getTime(); + Query query = new Query(Criteria.where("mongoCreateTime").gte(DateUtils.getDayStart(date)).lt(DateUtils.getDayEnd(date))); +// Query query = new Query(Criteria.where("mongoCreateTime").gte(DateUtils.getDayStart(new Date())).lt(DateUtils.getDayEnd(new Date()))); + List<MonitorQualifyResult> oneMachineFileResults = mongoTemplate.find(query, MonitorQualifyResult.class); //鏁版嵁搴搈onitor琛ㄦ暟鎹� - List<String> serialNumberInBase = monitorService.selectTMonitorList(null).stream().map(TMonitorVO::getSerialNumber).collect(Collectors.toList()); + Map<String, TMonitorVO> monitorVOMap = monitorMapper.selectMonitorVOList().stream().collect(Collectors.toMap(TMonitorVO::getSerialNumber, Function.identity())); //鍑嗗鎻掑叆璁惧琛ㄧ殑鏁版嵁 List<TMonitor> monitorList = new ArrayList<>(); //鍑嗗鎻掑叆鐐逛綅琛ㄧ殑鏁版嵁 @@ -65,67 +83,89 @@ sysDictData.setDictType("platform_important_site"); List<SysDictData> DictDataList = dictDataService.selectDictDataList(sysDictData); List<String> importantSite = DictDataList.stream().map(SysDictData::getDictValue).collect(Collectors.toList()); - for (OneMachineFileResult result : oneMachineFileResults) { - TMonitor monitor = getMonitor(result); + + //鍏ㄥ勾鐣欏瓨 + for (MonitorQualifyResult result : oneMachineFileResults) { + TMonitor monitor = getMonitor(result, monitorVOMap); YwPoint point = getPoint(result, pointMap, importantSite); monitorList.add(monitor); + ywPointList.add(point); //姣斿绛涢�夊嚭鏂扮殑鏁版嵁 - if (!CollectionUtils.isEmpty(serialNumberInBase) && !serialNumberInBase.contains(result.getSBBM())) { + if (!CollectionUtils.isEmpty(monitorVOMap) && !monitorVOMap.containsKey(result.getSerialNumber().getValue())) { newMonitorList.add(monitor); } } + log.info("result闆嗗悎{},璁惧闆嗗悎{},鐐逛綅闆嗗悎{}", oneMachineFileResults.size(), monitorList.size(), ywPointList.size()); //鎻掑叆鏁版嵁搴� if (!CollectionUtils.isEmpty(monitorList)) { - monitorService.deleteTMonitorById(null); - monitorService.saveBatch(monitorList); + monitorService.saveOrUpdateBatch(monitorList); + } + if (!CollectionUtils.isEmpty(ywPointList)) { + ywPointService.saveOrUpdateBatch(ywPointList); } //鏂扮殑鏁版嵁鏀惧叆Redis涓瓑寰呰�冩牳鎸囨爣浠诲姟浣跨敤 redisTemplate.opsForValue().set(RedisConstant.New_Monitor_Set, JSONArray.toJSONString(newMonitorList)); - - } - private YwPoint getPoint(OneMachineFileResult result, Map<String, YwPoint> pointMap, List<String> importantSite) { + private YwPoint getPoint(MonitorQualifyResult result, Map<String, YwPoint> pointMap, List<String> importantSite) { YwPoint ywPoint = new YwPoint(); - if (pointMap.containsKey(result.getSBBM())) { - ywPoint = pointMap.get(result.getSBBM()); - }else { - ywPoint.setPointName(result.getSBMC()); + if (pointMap.containsKey(result.getSerialNumber().getValue())) { + ywPoint = pointMap.get(result.getSerialNumber().getValue()); + } else { + ywPoint.setPointName(result.getName().getValue()); ywPoint.setStatus(PointStatus.WAIT.getDesc()); - ywPoint.setSerialNumber(result.getSBBM()); + ywPoint.setSerialNumber(result.getSerialNumber().getValue()); ywPoint.setImportantTag(Boolean.FALSE); ywPoint.setProvinceTag(Boolean.FALSE); ywPoint.setCreateTime(new Date()); ywPoint.setUpdateTime(new Date()); } //姣斿鏄惁鏄噸鐐圭偣浣� - if (importantSite.contains(result.getSBBM())) { + if (importantSite.contains(result.getSerialNumber().getValue())) { ywPoint.setImportantTag(Boolean.TRUE); } //瑙f瀽deptId //鍖哄煙琛屾斂缂栫爜 - String areaCode = result.getSBBM().substring(0, 6); - Integer deptId = AreaDeptEnum.fromCode(areaCode).getDeptId(); - if (deptId != null) { - ywPoint.setDeptId(Long.valueOf(deptId + "")); + String serialNumber = result.getSerialNumber().getValue(); + Integer deptId = -1; + if (!StringUtils.isEmpty(serialNumber)) { + String areaCode = serialNumber.substring(0, 6); + AreaDeptEnum areaDeptEnum = AreaDeptEnum.fromCode(areaCode); + //濡傛灉瑙f瀽涓嶅嚭鍖哄煙deptId涓�-1 + if (areaDeptEnum != null) { + deptId = areaDeptEnum.getDeptId(); + } } + ywPoint.setDeptId(Long.valueOf(deptId + "")); return ywPoint; } - private TMonitor getMonitor(OneMachineFileResult result) { + private TMonitor getMonitor(MonitorQualifyResult result, Map<String, TMonitorVO> monitorVOMap) { TMonitor monitor = new TMonitor(); - monitor.setSerialNumber(result.getSBBM()); - monitor.setName(result.getSBMC()); - monitor.setSiteType(Long.valueOf(result.getJKDWLX())); - monitor.setMacAddr(result.getMACDZ()); - monitor.setIp(result.getIP()); - monitor.setCameraFunType(result.getSXJGNLX()); - monitor.setLongitude(result.getJD() + ""); - monitor.setLatitude(result.getWD() + ""); - monitor.setCameraCaptureArea(result.getSXJCJQY()); - monitor.setOnState(Long.valueOf(result.getSBZT())); + if (monitorVOMap.containsKey(result.getSerialNumber().getValue())) { + monitor.setId(monitorVOMap.get(result.getSerialNumber().getValue()).getId()); + } + monitor.setSerialNumber(result.getSerialNumber().getValue()); + monitor.setName(result.getName().getValue()); + String siteType = result.getJkdwlx().getValue(); + if (!StringUtils.isEmpty(siteType)) { + monitor.setSiteType(Long.valueOf(siteType)); + } + monitor.setMacAddr(result.getMacdz().getValue()); + monitor.setIp(result.getIp().getValue()); + monitor.setCameraFunType(result.getSxjgnlx().getValue()); + monitor.setLongitude(result.getLongitude().getValue()); + monitor.setLatitude(result.getLatitude().getValue() + ""); + monitor.setCameraCaptureArea(result.getSxjcjqy().getValue()); + String onState = result.getSbzt().getValue(); + if (!StringUtils.isEmpty(onState)) { + monitor.setOnState(Long.valueOf(onState)); + } //鍥芥爣鐮佸墠鍏綅涓鸿鏀跨紪鐮� - monitor.setCivilCode(result.getSBBM().substring(0, 8)); + String serialNumber = result.getSerialNumber().getValue(); + if (!StringUtils.isEmpty(serialNumber)) { + monitor.setCivilCode(serialNumber.substring(0, 8)); + } return monitor; } } -- Gitblit v1.8.0