From be4a0fdb606425eff8e9db970b89d1e76e85987e Mon Sep 17 00:00:00 2001 From: tyty Date: Wed, 17 May 2023 15:45:14 +0800 Subject: [PATCH 1/2] =?UTF-8?q?=E9=80=9A=E8=AE=AF=E4=B8=AD=E6=96=AD?= =?UTF-8?q?=E5=91=8A=E8=AD=A6bug=E4=BF=AE=E5=A4=8D?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../hzims/operational/alert/vo/HistoryAlarmVo.java | 42 ++++++++++++++++++++++ .../alert/controller/AbnormalAlarmController.java | 17 ++++----- .../alert/service/HistoryAbnormalAlarmService.java | 11 +++--- .../impl/HistoryAbnormalAlarmServiceImpl.java | 15 ++++---- 4 files changed, 66 insertions(+), 19 deletions(-) create mode 100644 hzims-service-api/hzims-operational-api/src/main/java/com/hnac/hzims/operational/alert/vo/HistoryAlarmVo.java diff --git a/hzims-service-api/hzims-operational-api/src/main/java/com/hnac/hzims/operational/alert/vo/HistoryAlarmVo.java b/hzims-service-api/hzims-operational-api/src/main/java/com/hnac/hzims/operational/alert/vo/HistoryAlarmVo.java new file mode 100644 index 0000000..dad9dc4 --- /dev/null +++ b/hzims-service-api/hzims-operational-api/src/main/java/com/hnac/hzims/operational/alert/vo/HistoryAlarmVo.java @@ -0,0 +1,42 @@ +package com.hnac.hzims.operational.alert.vo; + +import io.swagger.annotations.ApiModelProperty; +import lombok.Data; +import org.springblade.core.mp.base.BaseEntity; + +import java.util.Date; +import java.util.List; + +@Data +public class HistoryAlarmVo extends BaseEntity { + + @ApiModelProperty("ID") + private Long id; + + @ApiModelProperty("站点编码") + private String stationId; + + @ApiModelProperty("站点名称") + private String stationName; + + @ApiModelProperty("告警编码") + private Long alarmId; + + @ApiModelProperty("检查点") + private String realId; + + @ApiModelProperty("告警开始时间") + private Date startTime; + + @ApiModelProperty("告警结束时间") + private Date endTime; + + @ApiModelProperty("告警类型") + private List type; + + @ApiModelProperty("状态") + private Integer status; + + @ApiModelProperty("告警原因") + private String soeExplain; +} \ No newline at end of file diff --git a/hzims-service/operational/src/main/java/com/hnac/hzims/operational/alert/controller/AbnormalAlarmController.java b/hzims-service/operational/src/main/java/com/hnac/hzims/operational/alert/controller/AbnormalAlarmController.java index f2fbf01..9602b7e 100644 --- a/hzims-service/operational/src/main/java/com/hnac/hzims/operational/alert/controller/AbnormalAlarmController.java +++ b/hzims-service/operational/src/main/java/com/hnac/hzims/operational/alert/controller/AbnormalAlarmController.java @@ -7,9 +7,10 @@ import com.hnac.hzims.operational.alert.entity.HistoryAbnormalAlarmEntity; import com.hnac.hzims.operational.alert.service.HistoryAbnormalAlarmService; import com.hnac.hzims.operational.alert.vo.AlarmParamVo; import com.hnac.hzims.operational.alert.vo.AlarmReustVo; -import com.hnac.hzims.operational.alert.vo.SoeParamVo; -import com.hnac.hzims.operational.alert.vo.SoeReustVo; -import com.hnac.hzims.operational.config.vo.*; +import com.hnac.hzims.operational.alert.vo.HistoryAlarmVo; +import com.hnac.hzims.operational.config.vo.AlarmDataPageVo; +import com.hnac.hzims.operational.config.vo.AlarmVo; +import com.hnac.hzims.operational.config.vo.IntelligentAlarmCountVo; import com.hnac.hzims.operational.station.vo.HistoryAbnormalAlarmVo; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; @@ -40,10 +41,10 @@ public class AbnormalAlarmController extends BladeController { * 统计通讯中断时间 */ @ApiLog - @GetMapping("/statisticsTime") + @RequestMapping(value = "/statisticsTime", method = {RequestMethod.GET, RequestMethod.POST}) @ApiOperationSupport(order = 1) @ApiOperation(value = "统计通讯中断时间", notes = "传入imsDutyMainEntity") - public R> statisticsTime(HistoryAbnormalAlarmEntity entity, Query query) { + public R> statisticsTime(HistoryAlarmVo entity, Query query) { IPage pages = service.getAlarmTime(query,entity); return R.data(pages); } @@ -52,10 +53,10 @@ public class AbnormalAlarmController extends BladeController { * 统计通讯中断二级目录查询 */ @ApiLog - @GetMapping("/queryByEntity") + @RequestMapping(value = "/queryByEntity", method = {RequestMethod.GET, RequestMethod.POST}) @ApiOperationSupport(order = 1) @ApiOperation(value = "统计通讯中断二级目录查询", notes = "传入imsDutyMainEntity") - public R> queryByEntity(HistoryAbnormalAlarmEntity entity, Query query) { + public R> queryByEntity(HistoryAlarmVo entity, Query query) { IPage pages = service.queryByEntity(entity,query); return R.data(pages); } @@ -72,7 +73,7 @@ public class AbnormalAlarmController extends BladeController { * 详情 */ @ApiLog - @GetMapping("/detail") + @RequestMapping(value = "/detail", method = {RequestMethod.GET, RequestMethod.POST}) @ApiOperationSupport(order = 3) @ApiOperation(value = "详情", notes = "传入HistoryAbnormalAlarmEntity") public R detail(HistoryAbnormalAlarmEntity entity) { diff --git a/hzims-service/operational/src/main/java/com/hnac/hzims/operational/alert/service/HistoryAbnormalAlarmService.java b/hzims-service/operational/src/main/java/com/hnac/hzims/operational/alert/service/HistoryAbnormalAlarmService.java index 4f396c1..8ab23c1 100644 --- a/hzims-service/operational/src/main/java/com/hnac/hzims/operational/alert/service/HistoryAbnormalAlarmService.java +++ b/hzims-service/operational/src/main/java/com/hnac/hzims/operational/alert/service/HistoryAbnormalAlarmService.java @@ -4,9 +4,10 @@ import com.baomidou.mybatisplus.core.metadata.IPage; import com.hnac.hzims.operational.alert.entity.HistoryAbnormalAlarmEntity; import com.hnac.hzims.operational.alert.vo.AlarmParamVo; import com.hnac.hzims.operational.alert.vo.AlarmReustVo; -import com.hnac.hzims.operational.alert.vo.SoeParamVo; -import com.hnac.hzims.operational.alert.vo.SoeReustVo; -import com.hnac.hzims.operational.config.vo.*; +import com.hnac.hzims.operational.alert.vo.HistoryAlarmVo; +import com.hnac.hzims.operational.config.vo.AlarmDataPageVo; +import com.hnac.hzims.operational.config.vo.AlarmVo; +import com.hnac.hzims.operational.config.vo.IntelligentAlarmCountVo; import com.hnac.hzims.operational.station.vo.HistoryAbnormalAlarmVo; import org.springblade.core.mp.base.BaseService; import org.springblade.core.mp.support.Query; @@ -23,9 +24,9 @@ public interface HistoryAbnormalAlarmService extends BaseService list(IPage page, String type); - IPage getAlarmTime(Query query, HistoryAbnormalAlarmEntity entity); + IPage getAlarmTime(Query query, HistoryAlarmVo entity); - IPage queryByEntity(HistoryAbnormalAlarmEntity entity,Query query); + IPage queryByEntity(HistoryAlarmVo entity,Query query); AlarmReustVo alarms(AlarmParamVo param); diff --git a/hzims-service/operational/src/main/java/com/hnac/hzims/operational/alert/service/impl/HistoryAbnormalAlarmServiceImpl.java b/hzims-service/operational/src/main/java/com/hnac/hzims/operational/alert/service/impl/HistoryAbnormalAlarmServiceImpl.java index 7da6a9e..07ab971 100644 --- a/hzims-service/operational/src/main/java/com/hnac/hzims/operational/alert/service/impl/HistoryAbnormalAlarmServiceImpl.java +++ b/hzims-service/operational/src/main/java/com/hnac/hzims/operational/alert/service/impl/HistoryAbnormalAlarmServiceImpl.java @@ -102,7 +102,7 @@ public class HistoryAbnormalAlarmServiceImpl extends BaseServiceImpl getAlarmTime(Query query, HistoryAbnormalAlarmEntity entity) { + public IPage getAlarmTime(Query query, HistoryAlarmVo entity) { QueryWrapper alarmEntityQueryWrapper = getAlarmEntityQueryWrapper(entity); List historyAbnormalAlarmEntity = this.baseMapper.selectList(alarmEntityQueryWrapper); if (historyAbnormalAlarmEntity == null) { @@ -131,8 +131,11 @@ public class HistoryAbnormalAlarmServiceImpl extends BaseServiceImpl getAlarmEntityQueryWrapper(HistoryAbnormalAlarmEntity entity) { + private QueryWrapper getAlarmEntityQueryWrapper(HistoryAlarmVo entity) { QueryWrapper queryWrapper = new QueryWrapper<>(); if (entity.getStationName() != null) { String[] list = entity.getStationName().split(","); queryWrapper.lambda().in(HistoryAbnormalAlarmEntity::getStationName, Arrays.stream(list).collect(Collectors.toList())); } if (entity.getType() != null) { - queryWrapper.lambda().eq(HistoryAbnormalAlarmEntity::getType, entity.getType()); + queryWrapper.lambda().in(HistoryAbnormalAlarmEntity::getType, entity.getType()); } if (entity.getStartTime() != null) { queryWrapper.lambda().ge(HistoryAbnormalAlarmEntity::getStartTime, entity.getStartTime()); @@ -174,7 +177,7 @@ public class HistoryAbnormalAlarmServiceImpl extends BaseServiceImpl queryByEntity(HistoryAbnormalAlarmEntity entity, Query query) { + public IPage queryByEntity(HistoryAlarmVo entity, Query query) { QueryWrapper alarmEntityQueryWrapper = getAlarmEntityQueryWrapper(entity); IPage historyAbnormalAlarmEntityIPage = this.baseMapper.selectPage(Condition.getPage(query), alarmEntityQueryWrapper); List records = historyAbnormalAlarmEntityIPage.getRecords(); From c0428a031f0c3ff24f72651f02d7d1cec97aa69f Mon Sep 17 00:00:00 2001 From: yang_shj <1069818635@QQ.com> Date: Thu, 18 May 2023 17:19:40 +0800 Subject: [PATCH 2/2] =?UTF-8?q?#bug=E4=BF=AE=E6=94=B9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../equipment/service/impl/EmInfoServiceImpl.java | 51 +++++++++++++++++----- .../service/impl/AbnormalAlarmServiceImpl.java | 18 +++----- .../impl/HistoryAbnormalAlarmServiceImpl.java | 2 +- .../duty/service/impl/ImsDutyMainServiceImpl.java | 3 ++ .../main/service/impl/HydropowerServiceImpl.java | 4 +- .../main/service/impl/PhotovoltaicServiceImpl.java | 2 +- .../main/service/impl/WaterServiceImpl.java | 2 +- 7 files changed, 54 insertions(+), 28 deletions(-) diff --git a/hzims-service/equipment/src/main/java/com/hnac/hzims/equipment/service/impl/EmInfoServiceImpl.java b/hzims-service/equipment/src/main/java/com/hnac/hzims/equipment/service/impl/EmInfoServiceImpl.java index 1328a1d..18bf630 100644 --- a/hzims-service/equipment/src/main/java/com/hnac/hzims/equipment/service/impl/EmInfoServiceImpl.java +++ b/hzims-service/equipment/src/main/java/com/hnac/hzims/equipment/service/impl/EmInfoServiceImpl.java @@ -6,6 +6,7 @@ import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.toolkit.IdWorker; import com.baomidou.mybatisplus.core.toolkit.Wrappers; +import com.google.api.client.util.Sleeper; import com.google.common.collect.Lists; import com.hnac.hzims.equipment.EquipmentContants; import com.hnac.hzims.equipment.entity.*; @@ -21,6 +22,7 @@ import com.hnac.hzinfo.datasearch.analyse.IAnalyseDataSearchClient; import com.hnac.hzinfo.datasearch.analyse.vo.AnalyzeCodeBySignagesVO; import com.hnac.hzinfo.sdk.analyse.po.MultiAnalyzeCodePO; import com.hnac.hzinfo.sdk.v5.device.client.DeviceClient; +import lombok.extern.slf4j.Slf4j; import org.apache.commons.collections4.MapUtils; import org.springblade.core.log.exception.ServiceException; import org.springblade.core.mp.base.BaseServiceImpl; @@ -38,6 +40,7 @@ import org.springframework.util.Assert; import javax.validation.Valid; import java.util.*; import java.util.stream.Collectors; +import java.util.stream.Stream; /** * 服务实现类 @@ -45,6 +48,7 @@ import java.util.stream.Collectors; * @author Chill */ @Service +@Slf4j public class EmInfoServiceImpl extends BaseServiceImpl implements IEmInfoService { @Autowired private IEmParamService paramService; @@ -77,6 +81,11 @@ public class EmInfoServiceImpl extends BaseServiceImpl getEmInfoByCode(String emCode) { EmInfoNoScopeMapper mapper = SpringUtil.getBean("emInfoNoScopeMapper"); @@ -417,29 +426,38 @@ public class EmInfoServiceImpl extends BaseServiceImpl list = this.baseMapper.selectEminfoAndEmParamVoList(); + List devices = this.baseMapper.selectEminfoAndEmParamVoList(); // 查询所有设备(ct、pt、installedCapacity)配置参数 List paramList = this.paramService.getParamByParamNameGenerate(); - // 获取设备监测点 // 获取设备监测点位:未配置监测点位不进行统计设备 - List multiAnalyzeCodePOList = list.stream().map(o->{ + List multiAnalyzeCodePOList = devices.stream().map(o->{ MultiAnalyzeCodePO multiAnalyzeCodePO = new MultiAnalyzeCodePO(); multiAnalyzeCodePO.setDeviceCode(o.getEmCode()); multiAnalyzeCodePO.setSignages(HomePageConstant.SIGNAGES); return multiAnalyzeCodePO; }).collect(Collectors.toList()); - R> result = searchClient.getAnalyzeCodeBySignages(multiAnalyzeCodePOList); - if(!result.isSuccess() || CollectionUtil.isEmpty(result.getData())){ - return; - } + // 切割 + int limit = countStep(multiAnalyzeCodePOList.size()); + List> lists = Stream.iterate(0, n -> n + 1).limit(limit).parallel().map(a -> multiAnalyzeCodePOList.stream().skip((long) a * MAX_SEND).limit(MAX_SEND).parallel().collect(Collectors.toList())).collect(Collectors.toList()); + // 接收数据 + List analys = new ArrayList<>(); + lists.forEach(list->{ + R> result = searchClient.getAnalyzeCodeBySignages(list); + if(!result.isSuccess() || CollectionUtil.isEmpty(result.getData())){ + return; + } + analys.addAll(result.getData()); + }); // 设备遍历 - list.forEach(item->{ + devices.forEach(item->{ item.setRideCount(1); item.setInstalledCapacity(0.0); + List signages = analys.stream().filter(o-> item.getEmCode().equals(o.getDeviceCode()) && !StringUtil.isEmpty(o.getSignage()) && !StringUtil.isEmpty(o.getRealId())).collect(Collectors.toList()); + if(CollectionUtil.isEmpty(signages)){ + return; + } // list -> map - item.setPoint(result.getData().stream().filter(o-> item.getEmCode().equals(o.getDeviceCode()) && StringUtil.isNotBlank(o.getSignage()) && StringUtil.isNotBlank(o.getRealId())). - collect(Collectors.toMap(AnalyzeCodeBySignagesVO::getSignage,AnalyzeCodeBySignagesVO::getRealId))); - + item.setPoint(signages.stream().collect(Collectors.toMap(AnalyzeCodeBySignagesVO::getSignage,AnalyzeCodeBySignagesVO::getRealId))); // 寻找设备配置参数 List itemParamList = paramList.stream().filter(o->item.getId().equals(o.getInfoId())).collect(Collectors.toList()); if(CollectionUtil.isNotEmpty(itemParamList)){ @@ -456,6 +474,8 @@ public class EmInfoServiceImpl extends BaseServiceImpl Math.abs(o.getInstalledCapacity()) > 0 || MapUtils.isNotEmpty(o.getPoint())).collect(Collectors.toList()))); + redisTemplate.opsForValue().set(em_info_list_path, JSONObject.toJSONString(devices.stream().filter(o-> Math.abs(o.getInstalledCapacity()) > 0 || MapUtils.isNotEmpty(o.getPoint())).collect(Collectors.toList()))); + } + + /** + * 计算切分次数 + */ + private static Integer countStep(Integer size) { + return (size + MAX_SEND - 1) / MAX_SEND; } private void validEmInfo(EmInfoAddVo em_info) { diff --git a/hzims-service/operational/src/main/java/com/hnac/hzims/operational/alert/service/impl/AbnormalAlarmServiceImpl.java b/hzims-service/operational/src/main/java/com/hnac/hzims/operational/alert/service/impl/AbnormalAlarmServiceImpl.java index e59097d..f8d4c68 100644 --- a/hzims-service/operational/src/main/java/com/hnac/hzims/operational/alert/service/impl/AbnormalAlarmServiceImpl.java +++ b/hzims-service/operational/src/main/java/com/hnac/hzims/operational/alert/service/impl/AbnormalAlarmServiceImpl.java @@ -71,14 +71,13 @@ public class AbnormalAlarmServiceImpl extends BaseServiceImpl> result = soeClient.getByStationsAndTime(query); @@ -88,8 +87,8 @@ public class AbnormalAlarmServiceImpl extends BaseServiceImpl list = result.getData().getRecords().stream().sorted(Comparator.comparing(SoeData::getTs).reversed()) - .collect(Collectors.toMap(o->o.getStation()+o.getSoeType(),Function.identity(),(o1, o2) -> o1)).entrySet().stream().map(Map.Entry::getValue).collect(Collectors.toList()); + List list = new ArrayList<>(result.getData().getRecords().stream().sorted(Comparator.comparing(SoeData::getTs).reversed()) + .collect(Collectors.toMap(o -> o.getStation() + o.getSoeType(), Function.identity(), (o1, o2) -> o1)).values()); log.error("alarm_data_handle_end_result : {}",list); list.forEach(item -> { AbnormalAlarmEntity queryEntity = this.baseMapper.getAbnormalAlarm(item.getStation(),item.getSoeType()); @@ -160,6 +159,7 @@ public class AbnormalAlarmServiceImpl extends BaseServiceImpl o.getCode().equals(item.getStation())).collect(Collectors.toList())).map(o->o.get(0).getName()).orElse(null); if(ObjectUtil.isEmpty(queryEntity) || !flag){ HistoryAbnormalAlarmEntity entity = new HistoryAbnormalAlarmEntity(); + entity.setAlarmId(item.getId()); entity.setStationId(item.getStation()); entity.setStationName(stationName); entity.setRealId(item.getRealId()); @@ -172,13 +172,9 @@ public class AbnormalAlarmServiceImpl extends BaseServiceImpl wrapper = Wrappers.lambdaQuery(); + wrapper.eq(StationEntity::getServeType,HomePageConstant.HYDROPOWER_SERVETYPE); if(StringUtils.isNotEmpty(param.getCode())){ wrapper.eq(StationEntity::getCode,param.getCode()); } @@ -215,7 +216,6 @@ public class HistoryAbnormalAlarmServiceImpl extends BaseServiceImpl() {{ eq(ImsDutyMainPersonEntity::getDutyMainId, dutyMainInfoVo.getId()); diff --git a/hzims-service/operational/src/main/java/com/hnac/hzims/operational/main/service/impl/HydropowerServiceImpl.java b/hzims-service/operational/src/main/java/com/hnac/hzims/operational/main/service/impl/HydropowerServiceImpl.java index 07dd56e..b7535a6 100644 --- a/hzims-service/operational/src/main/java/com/hnac/hzims/operational/main/service/impl/HydropowerServiceImpl.java +++ b/hzims-service/operational/src/main/java/com/hnac/hzims/operational/main/service/impl/HydropowerServiceImpl.java @@ -285,7 +285,7 @@ public class HydropowerServiceImpl implements HydropowerService { private List getLoadsByDay(EminfoAndEmParamVo device) { String start = DateUtil.format(new Date(), DateUtil.PATTERN_DATE) + " 00:00:00"; String end = DateUtil.format(new Date(), DateUtil.PATTERN_DATETIME); - List records = analyseDataService.periodTargetData(start, end, 1, 2, device.getEmCode(), HomePageConstant.PV_LOAD); + List records = analyseDataService.periodTargetData(start, end, 3, 2, device.getEmCode(), HomePageConstant.PV_LOAD); if (CollectionUtil.isEmpty(records)) { return new ArrayList<>(); } @@ -526,7 +526,7 @@ public class HydropowerServiceImpl implements HydropowerService { GenerationPowerVo generate = new GenerationPowerVo(); Date time = DateUtil.parse(record.getTs(), "yyyy-MM-dd HH:mm:ss.s"); generate.setDate(DateUtil.format(time,DateUtil.PATTERN_DATE)); - generate.setGenerate(Float.valueOf(Optional.ofNullable(record.getVal()).orElse("0"))); + generate.setGenerate(Float.parseFloat(Optional.ofNullable(record.getVal()).orElse("0")) * device.getRideCount()); return generate; }).collect(Collectors.toList()); } diff --git a/hzims-service/operational/src/main/java/com/hnac/hzims/operational/main/service/impl/PhotovoltaicServiceImpl.java b/hzims-service/operational/src/main/java/com/hnac/hzims/operational/main/service/impl/PhotovoltaicServiceImpl.java index 9042377..173e3dd 100644 --- a/hzims-service/operational/src/main/java/com/hnac/hzims/operational/main/service/impl/PhotovoltaicServiceImpl.java +++ b/hzims-service/operational/src/main/java/com/hnac/hzims/operational/main/service/impl/PhotovoltaicServiceImpl.java @@ -487,7 +487,7 @@ public class PhotovoltaicServiceImpl implements PhotovoltaicService { return "0"; } String value = map.get(realId); - if (StringUtil.isEmpty(realId)) { + if (StringUtil.isEmpty(value)) { return "0"; } // 获取value diff --git a/hzims-service/operational/src/main/java/com/hnac/hzims/operational/main/service/impl/WaterServiceImpl.java b/hzims-service/operational/src/main/java/com/hnac/hzims/operational/main/service/impl/WaterServiceImpl.java index 09b81b3..83c7f71 100644 --- a/hzims-service/operational/src/main/java/com/hnac/hzims/operational/main/service/impl/WaterServiceImpl.java +++ b/hzims-service/operational/src/main/java/com/hnac/hzims/operational/main/service/impl/WaterServiceImpl.java @@ -521,7 +521,7 @@ public class WaterServiceImpl implements IWaterService { return "0"; } String value = map.get(realId); - if(StringUtil.isBlank(realId)){ + if(StringUtil.isBlank(value)){ return "0"; } // 获取value