海南数据不一致问题处理

This commit is contained in:
2025-12-26 15:29:33 +08:00
parent c3cc39973e
commit faac7953d3
10 changed files with 179 additions and 48 deletions

View File

@@ -322,10 +322,7 @@ public class SgEventServiceImpl extends ServiceImpl<SgEventMapper, SgEvent> impl
@Override @Override
public boolean deleteEventData(List<String> ids) { public boolean deleteEventData(List<String> ids) {
return this.lambdaUpdate() return this.removeByIds(ids);
.set(SgEvent::getState, DataStateEnum.DELETED.getCode())
.in(SgEvent::getId, ids)
.update();
} }
@Override @Override

View File

@@ -8,4 +8,8 @@ public class PublicDTO {
private String id; private String id;
private Double data; private Double data;
private Integer onlineMin;
private Integer offlineMin;
} }

View File

@@ -136,6 +136,18 @@ public class LineIntegrityDataVO implements Serializable {
@ApiModelProperty(name = "integrityData",value = "数据完整性") @ApiModelProperty(name = "integrityData",value = "数据完整性")
private Double integrityData; private Double integrityData;
/**
* 实际时间
*/
@ApiModelProperty(name = "realTime",value = "实际时间")
private Integer realTime;
/**
* 期望时间
*/
@ApiModelProperty(name = "dueTime",value = "期望时间")
private Integer dueTime;
/** /**
* 监测点合格率 * 监测点合格率
*/ */

View File

@@ -77,6 +77,18 @@ public class TerminalOnlineRateDataVO implements Serializable {
@ApiModelProperty(name = "onlineRate",value = "在线率") @ApiModelProperty(name = "onlineRate",value = "在线率")
private Double onlineRate; private Double onlineRate;
/**
* 在线分钟数
*/
@ApiModelProperty(name = "onlineMin",value = "在线分钟数")
private Integer onlineMin;
/**
* 离线分钟数
*/
@ApiModelProperty(name = "offlineMin",value = "离线分钟数")
private Integer offlineMin;
/** /**
* 最新数据时间 * 最新数据时间
*/ */

View File

@@ -5,8 +5,7 @@
select select
dev_index, dev_index,
sum(online_min) as onlineMin, sum(online_min) as onlineMin,
sum(offline_min) as offlineMin, sum(offline_min) as offlineMin
ROUND( sum(online_min)*1.0/(sum(online_min) + sum(offline_min))*100,2) as onlineRate
from r_stat_onlinerate_d from r_stat_onlinerate_d
<where> <where>
<if test="param!=null and param.ids != null and param.ids.size > 0"> <if test="param!=null and param.ids != null and param.ids.size > 0">

View File

@@ -176,7 +176,6 @@
<select id="getDevOnlineByDevIds" resultType="TerminalOnlineRateData"> <select id="getDevOnlineByDevIds" resultType="TerminalOnlineRateData">
select select
dev_index devId, dev_index devId,
avg(online_min/(online_min+offline_min))*100 onlineRate,
sum(online_min) onlineMin, sum(online_min) onlineMin,
sum(offline_min) offlineMin sum(offline_min) offlineMin
from r_stat_onlinerate_d from r_stat_onlinerate_d

View File

@@ -173,13 +173,17 @@ public class LineIntegrityDataServiceImpl extends ServiceImpl<LineIntegrityDataM
} }
// 数据封装 // 数据封装
Double temValue = lineList.stream().filter(item -> item.getIntegrityData() != 3.14159).mapToDouble(LineIntegrityDataVO::getIntegrityData).average().orElse(3.14159); // 汇总所有监测点的实际时间和期望时间,重新计算完整性
int totalRealTime = (int) lineList.stream().filter(item -> item.getIntegrityData() != 3.14159).mapToLong(LineIntegrityDataVO::getRealTime).sum();
int totalDueTime = (int) lineList.stream().filter(item -> item.getIntegrityData() != 3.14159).mapToLong(LineIntegrityDataVO::getDueTime).sum();
lineIntegrityDataVO.setRealTime(totalRealTime);
lineIntegrityDataVO.setDueTime(totalDueTime);
lineIntegrityDataVO.setIntegrityData(DataStatisticsUtil.calculateIntegrityRate(totalRealTime, totalDueTime));
LineIntegrityDataVO temp = lineList.stream().filter(t -> t.getAlgoDescribe() != null).min(Comparator.comparing(LineIntegrityDataVO::getAlgoDescribe)).orElse(new LineIntegrityDataVO()); LineIntegrityDataVO temp = lineList.stream().filter(t -> t.getAlgoDescribe() != null).min(Comparator.comparing(LineIntegrityDataVO::getAlgoDescribe)).orElse(new LineIntegrityDataVO());
lineIntegrityDataVO.setAlgoDescribe(temp.getAlgoDescribe()); lineIntegrityDataVO.setAlgoDescribe(temp.getAlgoDescribe());
lineIntegrityDataVO.setId(generalDeviceDTO.getIndex()); lineIntegrityDataVO.setId(generalDeviceDTO.getIndex());
lineIntegrityDataVO.setName(generalDeviceDTO.getName()); lineIntegrityDataVO.setName(generalDeviceDTO.getName());
lineIntegrityDataVO.setLevel(0); lineIntegrityDataVO.setLevel(0);
lineIntegrityDataVO.setIntegrityData(DataStatisticsUtil.dataLimits(temValue));
pro.add(lineIntegrityDataVO); pro.add(lineIntegrityDataVO);
} }
@@ -193,12 +197,12 @@ public class LineIntegrityDataServiceImpl extends ServiceImpl<LineIntegrityDataM
private void dealDataJinDu(List<LineIntegrityDataVO> mList,LineIntegrityDataVO children){ private void dealDataJinDu(List<LineIntegrityDataVO> mList,LineIntegrityDataVO children){
double temValue = mList.stream().filter(it->it.getIntegrityData()!=3.14159).mapToDouble(LineIntegrityDataVO::getIntegrityData).average().orElse(3.14159); // 汇总子节点的实际时间和期望时间,重新计算完整性
if(temValue!=3.14159){ int totalRealTime = (int) mList.stream().filter(it->it.getIntegrityData()!=3.14159).mapToLong(LineIntegrityDataVO::getRealTime).sum();
children.setIntegrityData(new BigDecimal(temValue).setScale(2,RoundingMode.HALF_UP).doubleValue()); int totalDueTime = (int) mList.stream().filter(it->it.getIntegrityData()!=3.14159).mapToLong(LineIntegrityDataVO::getDueTime).sum();
}else { children.setRealTime(totalRealTime);
children.setIntegrityData(temValue); children.setDueTime(totalDueTime);
} children.setIntegrityData(DataStatisticsUtil.calculateIntegrityRate(totalRealTime, totalDueTime));
} }
private void dealMonitorData(List<LineIntegrityDataVO> lineList,List<LineDataIntegrity> percentageOfCompleteDatas,Map<String, Integer> mapA){ private void dealMonitorData(List<LineIntegrityDataVO> lineList,List<LineDataIntegrity> percentageOfCompleteDatas,Map<String, Integer> mapA){
@@ -209,10 +213,13 @@ public class LineIntegrityDataServiceImpl extends ServiceImpl<LineIntegrityDataM
if(dataIntegrityMap.containsKey(monitor.getId())){ if(dataIntegrityMap.containsKey(monitor.getId())){
flag = true; flag = true;
LineDataIntegrity integrity = dataIntegrityMap.get(monitor.getId()); LineDataIntegrity integrity = dataIntegrityMap.get(monitor.getId());
monitor.setIntegrityData(DataStatisticsUtil.dataLimits(integrity.getIntegrityData())); monitor.setRealTime(integrity.getReal() == null ? 0 : integrity.getReal().intValue());
monitor.setDueTime(integrity.getDue() == null ? 0 : integrity.getDue().intValue());
Double integrityData = DataStatisticsUtil.calculateIntegrityRate(monitor.getRealTime(), monitor.getDueTime());
monitor.setIntegrityData(integrityData);
if (StrUtil.isNotBlank(monitor.getLineGrade())) { if (StrUtil.isNotBlank(monitor.getLineGrade())) {
if (mapA.containsKey(monitor.getLineGrade())) { if (mapA.containsKey(monitor.getLineGrade())) {
if (integrity.getIntegrityData() > mapA.get(monitor.getLineGrade())) { if (integrityData != 3.14159 && integrityData > mapA.get(monitor.getLineGrade())) {
monitor.setValueOver(1); monitor.setValueOver(1);
} else { } else {
monitor.setValueOver(0); monitor.setValueOver(0);
@@ -228,6 +235,8 @@ public class LineIntegrityDataServiceImpl extends ServiceImpl<LineIntegrityDataM
if (!flag) { if (!flag) {
//表示未匹配到数据完整性 //表示未匹配到数据完整性
monitor.setIntegrityData(3.14159); monitor.setIntegrityData(3.14159);
monitor.setRealTime(0);
monitor.setDueTime(0);
monitor.setValueOver(0); monitor.setValueOver(0);
} }
} }
@@ -248,13 +257,19 @@ public class LineIntegrityDataServiceImpl extends ServiceImpl<LineIntegrityDataM
outParam.setType(generalDeviceDTO.getName() + "\n(" + generalDeviceDTO.getLineIndexes().size() + ")"); outParam.setType(generalDeviceDTO.getName() + "\n(" + generalDeviceDTO.getLineIndexes().size() + ")");
//根据监测点查询数据完整性 //根据监测点查询数据完整性
List<PublicDTO> integrityData = getCondition(lineIndexes, integrityIconParam.getSearchBeginTime(), integrityIconParam.getSearchEndTime()); List<PublicDTO> integrityData = getCondition(lineIndexes, integrityIconParam.getSearchBeginTime(), integrityIconParam.getSearchEndTime());
double v = integrityData.stream().mapToDouble(PublicDTO::getData).average().orElse(3.14159); // 汇总所有监测点的实际时间和期望时间,再计算总完整性
outParam.setSingle(v!=3.14159?NumberUtil.round(v,2).doubleValue():v); int totalRealTime = (int) integrityData.stream().mapToLong(PublicDTO::getOnlineMin).sum();
int totalDueTime = (int) integrityData.stream().mapToLong(PublicDTO::getOfflineMin).sum();
double v = DataStatisticsUtil.calculateIntegrityRate(totalRealTime, totalDueTime);
outParam.setSingle(v);
//如果存在需要比较的时间,再获取对应数据 //如果存在需要比较的时间,再获取对应数据
if (StrUtil.isNotBlank(integrityIconParam.getPeriodBeginTime()) && StrUtil.isNotBlank(integrityIconParam.getPeriodEndTime())) { if (StrUtil.isNotBlank(integrityIconParam.getPeriodBeginTime()) && StrUtil.isNotBlank(integrityIconParam.getPeriodEndTime())) {
List<PublicDTO> compareData = getCondition(lineIndexes, integrityIconParam.getPeriodBeginTime(), integrityIconParam.getPeriodEndTime()); List<PublicDTO> compareData = getCondition(lineIndexes, integrityIconParam.getPeriodBeginTime(), integrityIconParam.getPeriodEndTime());
double v1 = compareData.stream().mapToDouble(PublicDTO::getData).average().orElse(3.14159); // 汇总所有监测点的实际时间和期望时间,再计算总完整性
outParam.setRatio(v1!=3.14159?NumberUtil.round(v1,2).doubleValue():v1); int compareRealTime = (int) compareData.stream().mapToLong(PublicDTO::getOnlineMin).sum();
int compareDueTime = (int) compareData.stream().mapToLong(PublicDTO::getOfflineMin).sum();
double v1 = DataStatisticsUtil.calculateIntegrityRate(compareRealTime, compareDueTime);
outParam.setRatio(v1);
} }
out.add(outParam); out.add(outParam);
} }
@@ -320,12 +335,14 @@ public class LineIntegrityDataServiceImpl extends ServiceImpl<LineIntegrityDataM
for (LineDataIntegrity lineData : percentageOfCompleteDatas) { for (LineDataIntegrity lineData : percentageOfCompleteDatas) {
if (lineDataIntegrity.getId().equals(lineData.getLineId())) { if (lineDataIntegrity.getId().equals(lineData.getLineId())) {
flag = true; flag = true;
Double temValue = lineData.getIntegrityData(); lineDataIntegrity.setRealTime(lineData.getReal() == null ? 0 : lineData.getReal().intValue());
lineDataIntegrity.setIntegrityData(DataStatisticsUtil.dataLimits(temValue)); lineDataIntegrity.setDueTime(lineData.getDue() == null ? 0 : lineData.getDue().intValue());
Double temValue = DataStatisticsUtil.calculateIntegrityRate(lineDataIntegrity.getRealTime(), lineDataIntegrity.getDueTime());
lineDataIntegrity.setIntegrityData(temValue);
//根据等级判断是否越限 //根据等级判断是否越限
if (StrUtil.isNotBlank(lineDataIntegrity.getLineGrade())) { if (StrUtil.isNotBlank(lineDataIntegrity.getLineGrade())) {
if (mapA.containsKey(lineDataIntegrity.getLineGrade())) { if (mapA.containsKey(lineDataIntegrity.getLineGrade())) {
if (temValue > mapA.get(lineDataIntegrity.getLineGrade())) { if (temValue != 3.14159 && temValue > mapA.get(lineDataIntegrity.getLineGrade())) {
lineDataIntegrity.setValueOver(1); lineDataIntegrity.setValueOver(1);
} else { } else {
lineDataIntegrity.setValueOver(0); lineDataIntegrity.setValueOver(0);
@@ -343,6 +360,8 @@ public class LineIntegrityDataServiceImpl extends ServiceImpl<LineIntegrityDataM
if (!flag) { if (!flag) {
//表示未匹配到数据完整性 //表示未匹配到数据完整性
lineDataIntegrity.setIntegrityData(3.14159); lineDataIntegrity.setIntegrityData(3.14159);
lineDataIntegrity.setRealTime(0);
lineDataIntegrity.setDueTime(0);
lineDataIntegrity.setValueOver(0); lineDataIntegrity.setValueOver(0);
} }
} }
@@ -352,13 +371,17 @@ public class LineIntegrityDataServiceImpl extends ServiceImpl<LineIntegrityDataM
lineIntegrityDataVO.setChildren(subList); lineIntegrityDataVO.setChildren(subList);
// 数据封装 // 数据封装
Double temValue = lineList.stream().filter(item -> item.getIntegrityData() != 3.14159).mapToDouble(LineIntegrityDataVO::getIntegrityData).average().orElse(3.14159); // 汇总所有监测点的实际时间和期望时间,重新计算完整性
int totalRealTime = (int) lineList.stream().filter(item -> item.getIntegrityData() != 3.14159).mapToLong(LineIntegrityDataVO::getRealTime).sum();
int totalDueTime = (int) lineList.stream().filter(item -> item.getIntegrityData() != 3.14159).mapToLong(LineIntegrityDataVO::getDueTime).sum();
lineIntegrityDataVO.setRealTime(totalRealTime);
lineIntegrityDataVO.setDueTime(totalDueTime);
lineIntegrityDataVO.setIntegrityData(DataStatisticsUtil.calculateIntegrityRate(totalRealTime, totalDueTime));
LineIntegrityDataVO temp = lineList.stream().filter(t -> t.getAlgoDescribe() != null).min(Comparator.comparing(LineIntegrityDataVO::getAlgoDescribe)).orElse(new LineIntegrityDataVO()); LineIntegrityDataVO temp = lineList.stream().filter(t -> t.getAlgoDescribe() != null).min(Comparator.comparing(LineIntegrityDataVO::getAlgoDescribe)).orElse(new LineIntegrityDataVO());
lineIntegrityDataVO.setAlgoDescribe(temp.getAlgoDescribe()); lineIntegrityDataVO.setAlgoDescribe(temp.getAlgoDescribe());
lineIntegrityDataVO.setId(generalDeviceDTO.getIndex()); lineIntegrityDataVO.setId(generalDeviceDTO.getIndex());
lineIntegrityDataVO.setName(generalDeviceDTO.getName()); lineIntegrityDataVO.setName(generalDeviceDTO.getName());
lineIntegrityDataVO.setLevel(0); lineIntegrityDataVO.setLevel(0);
lineIntegrityDataVO.setIntegrityData(Math.min(DataStatisticsUtil.dataLimits(temValue),100.0));
pro.add(lineIntegrityDataVO); pro.add(lineIntegrityDataVO);
} }
@@ -397,9 +420,12 @@ public class LineIntegrityDataServiceImpl extends ServiceImpl<LineIntegrityDataM
for (String pid : pids) { for (String pid : pids) {
if (lineAdministrationTree.getId().equals(pid)) { if (lineAdministrationTree.getId().equals(pid)) {
List<LineIntegrityDataVO> lineIntegrityDataVOList = groupLine.get(pid); List<LineIntegrityDataVO> lineIntegrityDataVOList = groupLine.get(pid);
//父级完整性匹配 //父级完整性匹配 - 汇总子节点的实际时间和期望时间,重新计算完整性
Double temValue = lineIntegrityDataVOList.stream().filter(item -> item.getIntegrityData() != 3.14159).mapToDouble(LineIntegrityDataVO::getIntegrityData).average().orElse(3.14159); int totalRealTime = (int) lineIntegrityDataVOList.stream().filter(item -> item.getIntegrityData() != 3.14159).mapToLong(LineIntegrityDataVO::getRealTime).sum();
lineAdministrationTree.setIntegrityData(DataStatisticsUtil.dataLimits(temValue)); int totalDueTime = (int) lineIntegrityDataVOList.stream().filter(item -> item.getIntegrityData() != 3.14159).mapToLong(LineIntegrityDataVO::getDueTime).sum();
lineAdministrationTree.setRealTime(totalRealTime);
lineAdministrationTree.setDueTime(totalDueTime);
lineAdministrationTree.setIntegrityData(DataStatisticsUtil.calculateIntegrityRate(totalRealTime, totalDueTime));
LineIntegrityDataVO temp = lineIntegrityDataVOList.stream().filter(t -> t.getAlgoDescribe() != null).min(Comparator.comparing(LineIntegrityDataVO::getAlgoDescribe)).orElse(new LineIntegrityDataVO()); LineIntegrityDataVO temp = lineIntegrityDataVOList.stream().filter(t -> t.getAlgoDescribe() != null).min(Comparator.comparing(LineIntegrityDataVO::getAlgoDescribe)).orElse(new LineIntegrityDataVO());
lineAdministrationTree.setAlgoDescribe(temp.getAlgoDescribe()); lineAdministrationTree.setAlgoDescribe(temp.getAlgoDescribe());
} }
@@ -418,10 +444,12 @@ public class LineIntegrityDataServiceImpl extends ServiceImpl<LineIntegrityDataM
if (!CollectionUtils.isEmpty(data)) { if (!CollectionUtils.isEmpty(data)) {
data.forEach(po -> { data.forEach(po -> {
PublicDTO publicDTO = new PublicDTO(); PublicDTO publicDTO = new PublicDTO();
//数据完整性 保留四位小数
Double integrity = po.getIntegrityRate() == null ? 3.14159 : BigDecimal.valueOf(Double.parseDouble(po.getIntegrityRate().toString())).setScale(2, RoundingMode.HALF_UP).doubleValue();
publicDTO.setId(po.getLineIndex()); publicDTO.setId(po.getLineIndex());
publicDTO.setData((integrity > 100.00) ? 100.00 : integrity); publicDTO.setOnlineMin(po.getRealTime() == null ? 0 : po.getRealTime().intValue());
publicDTO.setOfflineMin(po.getDueTime() == null ? 0 : po.getDueTime().intValue());
// 计算数据完整性
Double integrity = DataStatisticsUtil.calculateIntegrityRate(publicDTO.getOnlineMin(), publicDTO.getOfflineMin());
publicDTO.setData(integrity);
integrityList.add(publicDTO); integrityList.add(publicDTO);
}); });
} }

View File

@@ -182,11 +182,17 @@ public class TerminalOnlineRateDataServiceImpl implements TerminalOnlineRateData
type.add(generalDeviceDTO.getName()+"\n("+generalDeviceDTO.getLineIndexes().size()+")"); type.add(generalDeviceDTO.getName()+"\n("+generalDeviceDTO.getLineIndexes().size()+")");
//根据终端索引集查询在线率 //根据终端索引集查询在线率
List<PublicDTO> onlineRateList = getCondition(deviceIndexes, onlineRateCensusParam.getSearchBeginTime(), onlineRateCensusParam.getSearchEndTime()); List<PublicDTO> onlineRateList = getCondition(deviceIndexes, onlineRateCensusParam.getSearchBeginTime(), onlineRateCensusParam.getSearchEndTime());
single.add(onlineRateList.stream().mapToDouble(PublicDTO::getData).average().orElse(3.14159)); // 汇总所有设备的在线分钟和离线分钟,再计算总在线率
int totalOnlineMin = (int) onlineRateList.stream().mapToLong(PublicDTO::getOnlineMin).sum();
int totalOfflineMin = (int) onlineRateList.stream().mapToLong(PublicDTO::getOfflineMin).sum();
single.add(DataStatisticsUtil.calculateOnlineRate(totalOnlineMin, totalOfflineMin));
//如果存在需要比较的时间,再获取对应数据 //如果存在需要比较的时间,再获取对应数据
if(StrUtil.isNotBlank(onlineRateCensusParam.getPeriodBeginTime()) && StrUtil.isNotBlank(onlineRateCensusParam.getPeriodEndTime())){ if(StrUtil.isNotBlank(onlineRateCensusParam.getPeriodBeginTime()) && StrUtil.isNotBlank(onlineRateCensusParam.getPeriodEndTime())){
List<PublicDTO> compareData = getCondition(deviceIndexes, onlineRateCensusParam.getPeriodBeginTime(), onlineRateCensusParam.getPeriodEndTime()); List<PublicDTO> compareData = getCondition(deviceIndexes, onlineRateCensusParam.getPeriodBeginTime(), onlineRateCensusParam.getPeriodEndTime());
ratio.add(compareData.stream().mapToDouble(PublicDTO::getData).average().orElse(3.14159)); // 汇总所有设备的在线分钟和离线分钟,再计算总在线率
int compareOnlineMin = (int) compareData.stream().mapToLong(PublicDTO::getOnlineMin).sum();
int compareOfflineMin = (int) compareData.stream().mapToLong(PublicDTO::getOfflineMin).sum();
ratio.add(DataStatisticsUtil.calculateOnlineRate(compareOnlineMin, compareOfflineMin));
} }
} }
} }
@@ -210,10 +216,12 @@ public class TerminalOnlineRateDataServiceImpl implements TerminalOnlineRateData
if (CollUtil.isNotEmpty(data)) { if (CollUtil.isNotEmpty(data)) {
data.forEach(po -> { data.forEach(po -> {
PublicDTO publicDTO = new PublicDTO(); PublicDTO publicDTO = new PublicDTO();
//终端在线率 保留两位小数
Double onlineRate = po.getOnlineRate() == null ? null : BigDecimal.valueOf(Double.parseDouble(po.getOnlineRate().toString())).setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();
publicDTO.setId(po.getDevIndex()); publicDTO.setId(po.getDevIndex());
publicDTO.setData(DataStatisticsUtil.dataLimits(onlineRate)); publicDTO.setOnlineMin(po.getOnlineMin() == null ? 0 : po.getOnlineMin().intValue());
publicDTO.setOfflineMin(po.getOfflineMin() == null ? 0 : po.getOfflineMin().intValue());
// 计算在线率
Double onlineRate = DataStatisticsUtil.calculateOnlineRate(publicDTO.getOnlineMin(), publicDTO.getOfflineMin());
publicDTO.setData(onlineRate);
publicDTOList.add(publicDTO); publicDTOList.add(publicDTO);
}); });
} }
@@ -321,14 +329,24 @@ public class TerminalOnlineRateDataServiceImpl implements TerminalOnlineRateData
} }
} }
} }
Double devAvg = children.stream().filter(item -> item.getOnlineRate() != 3.14159).collect(Collectors.averagingDouble(TerminalOnlineRateDataVO::getOnlineRate)); // 汇总子节点的在线分钟和离线分钟,重新计算在线率
devItem.setOnlineRate(devAvg); int totalOnlineMin = (int) children.stream().filter(item -> item.getOnlineRate() != 3.14159).mapToLong(TerminalOnlineRateDataVO::getOnlineMin).sum();
int totalOfflineMin = (int) children.stream().filter(item -> item.getOnlineRate() != 3.14159).mapToLong(TerminalOnlineRateDataVO::getOfflineMin).sum();
devItem.setOnlineMin(totalOnlineMin);
devItem.setOfflineMin(totalOfflineMin);
devItem.setOnlineRate(DataStatisticsUtil.calculateOnlineRate(totalOnlineMin, totalOfflineMin));
} }
} }
Double devAvg = devs.stream().filter(item -> item.getOnlineRate() != 3.14159).collect(Collectors.averagingDouble(TerminalOnlineRateDataVO::getOnlineRate)); // 汇总设备的在线分钟和离线分钟,重新计算变电站在线率
subItem.setOnlineRate(devAvg); int totalOnlineMin = (int)devs.stream().filter(item -> item.getOnlineRate() != 3.14159).mapToLong(TerminalOnlineRateDataVO::getOnlineMin).sum();
int totalOfflineMin = (int)devs.stream().filter(item -> item.getOnlineRate() != 3.14159).mapToLong(TerminalOnlineRateDataVO::getOfflineMin).sum();
subItem.setOnlineMin(totalOnlineMin);
subItem.setOfflineMin(totalOfflineMin);
subItem.setOnlineRate(DataStatisticsUtil.calculateOnlineRate(totalOnlineMin, totalOfflineMin));
} else { } else {
subItem.setOnlineRate(3.14159); subItem.setOnlineRate(3.14159);
subItem.setOnlineMin(0);
subItem.setOfflineMin(0);
} }
if (Objects.nonNull(subItem.getAlgoDescribe())) { if (Objects.nonNull(subItem.getAlgoDescribe())) {
if (mapAlarm.containsKey(subItem.getAlgoDescribe())) { if (mapAlarm.containsKey(subItem.getAlgoDescribe())) {
@@ -340,10 +358,16 @@ public class TerminalOnlineRateDataServiceImpl implements TerminalOnlineRateData
} }
} }
} }
Double subAvg = subs.stream().filter(item -> item.getOnlineRate() != 3.14159).collect(Collectors.averagingDouble(TerminalOnlineRateDataVO::getOnlineRate)); // 汇总变电站的在线分钟和离线分钟,重新计算供电公司在线率
gdItem.setOnlineRate(subAvg); int totalOnlineMin = (int) subs.stream().filter(item -> item.getOnlineRate() != 3.14159).mapToLong(TerminalOnlineRateDataVO::getOnlineMin).sum();
int totalOfflineMin = (int) subs.stream().filter(item -> item.getOnlineRate() != 3.14159).mapToLong(TerminalOnlineRateDataVO::getOfflineMin).sum();
gdItem.setOnlineMin(totalOnlineMin);
gdItem.setOfflineMin(totalOfflineMin);
gdItem.setOnlineRate(DataStatisticsUtil.calculateOnlineRate(totalOnlineMin, totalOfflineMin));
} else { } else {
gdItem.setOnlineRate(3.14159); gdItem.setOnlineRate(3.14159);
gdItem.setOnlineMin(0);
gdItem.setOfflineMin(0);
} }
if (Objects.nonNull(gdItem.getAlgoDescribe())) { if (Objects.nonNull(gdItem.getAlgoDescribe())) {
if (mapAlarm.containsKey(gdItem.getAlgoDescribe())) { if (mapAlarm.containsKey(gdItem.getAlgoDescribe())) {
@@ -355,10 +379,16 @@ public class TerminalOnlineRateDataServiceImpl implements TerminalOnlineRateData
} }
} }
} }
Double gdAvg = gds.stream().filter(item -> item.getOnlineRate() != 3.14159).collect(Collectors.averagingDouble(TerminalOnlineRateDataVO::getOnlineRate)); // 汇总供电公司的在线分钟和离线分钟,重新计算省会在线率
proItem.setOnlineRate(gdAvg); int totalOnlineMin = (int) gds.stream().filter(item -> item.getOnlineRate() != 3.14159).mapToLong(TerminalOnlineRateDataVO::getOnlineMin).sum();
int totalOfflineMin = (int) gds.stream().filter(item -> item.getOnlineRate() != 3.14159).mapToLong(TerminalOnlineRateDataVO::getOfflineMin).sum();
proItem.setOnlineMin(totalOnlineMin);
proItem.setOfflineMin(totalOfflineMin);
proItem.setOnlineRate(DataStatisticsUtil.calculateOnlineRate(totalOnlineMin, totalOfflineMin));
} else { } else {
proItem.setOnlineRate(3.14159); proItem.setOnlineRate(3.14159);
proItem.setOnlineMin(0);
proItem.setOfflineMin(0);
} }
if (Objects.nonNull(proItem.getAlgoDescribe())) { if (Objects.nonNull(proItem.getAlgoDescribe())) {
if (mapAlarm.containsKey(proItem.getAlgoDescribe())) if (mapAlarm.containsKey(proItem.getAlgoDescribe()))

View File

@@ -127,16 +127,26 @@ public class DataStatisticsUtil {
for (TerminalOnlineRateData onlineRateData : terminalOnlineRateList) { for (TerminalOnlineRateData onlineRateData : terminalOnlineRateList) {
if (onlineRateDataVO.getId().equals(onlineRateData.getDevId())) { if (onlineRateDataVO.getId().equals(onlineRateData.getDevId())) {
flag = true; flag = true;
onlineRateDataVO.setOnlineRate( dataLimits(onlineRateData.getOnlineRate())); onlineRateDataVO.setOnlineMin(onlineRateData.getOnlineMin());
onlineRateDataVO.setOfflineMin(onlineRateData.getOfflineMin());
// 根据onlineMin和offlineMin计算在线率
Double onlineRate = calculateOnlineRate(onlineRateData.getOnlineMin(), onlineRateData.getOfflineMin());
onlineRateDataVO.setOnlineRate(onlineRate);
break; break;
} }
} }
if (!flag) { if (!flag) {
onlineRateDataVO.setOnlineRate(3.14159); onlineRateDataVO.setOnlineRate(3.14159);
onlineRateDataVO.setOnlineMin(0);
onlineRateDataVO.setOfflineMin(0);
} }
}).collect(Collectors.toList()); }).collect(Collectors.toList());
} else { } else {
deviceList = deviceList.stream().peek(onlineRateDataVO -> onlineRateDataVO.setOnlineRate(3.14159)).collect(Collectors.toList()); deviceList = deviceList.stream().peek(onlineRateDataVO -> {
onlineRateDataVO.setOnlineRate(3.14159);
onlineRateDataVO.setOnlineMin(0);
onlineRateDataVO.setOfflineMin(0);
}).collect(Collectors.toList());
} }
} }
@@ -149,6 +159,45 @@ public class DataStatisticsUtil {
return data>100?100:data; return data>100?100:data;
} }
/**
* 根据在线分钟数和离线分钟数计算在线率
* @param onlineMin 在线分钟数
* @param offlineMin 离线分钟数
* @return 在线率保留两位小数超过100则返回100
*/
public static Double calculateOnlineRate(Integer onlineMin, Integer offlineMin) {
if (onlineMin == null || offlineMin == null) {
return 3.14159;
}
long totalMin = onlineMin + offlineMin;
if (totalMin == 0) {
return 3.14159;
}
double rate = onlineMin * 100.0 / totalMin;
// 保留两位小数
rate = Math.round(rate * 100.0) / 100.0;
return dataLimits(rate);
}
/**
* 根据实际时间和期望时间计算数据完整性
* @param realTime 实际时间
* @param dueTime 期望时间
* @return 数据完整性保留两位小数超过100则返回100
*/
public static Double calculateIntegrityRate(Integer realTime, Integer dueTime) {
if (realTime == null || dueTime == null) {
return 3.14159;
}
if (dueTime == 0) {
return 3.14159;
}
double rate = realTime * 100.0 / dueTime;
// 保留两位小数
rate = Math.round(rate * 100.0) / 100.0;
return dataLimits(rate);
}
} }

View File

@@ -19,7 +19,8 @@
<select id="getOnIntegrityByIds" resultType="com.njcn.device.pq.pojo.vo.RStatIntegrityVO"> <select id="getOnIntegrityByIds" resultType="com.njcn.device.pq.pojo.vo.RStatIntegrityVO">
SELECT SELECT
line_index AS lineIndex, line_index AS lineIndex,
ROUND(sum( real_time )*1.0 / sum( due_time ) * 100,2) AS integrityRate sum(real_time) AS realTime,
sum(due_time) AS dueTime
FROM FROM
r_stat_integrity_d r_stat_integrity_d
<where> <where>