From 2bdbda70e87188f4a398f5cf03e997fcaec150f4 Mon Sep 17 00:00:00 2001 From: dongyukun <1208714201@qq.com> Date: 星期三, 07 五月 2025 15:04:17 +0800 Subject: [PATCH] 根据outId查询预测数据 --- ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/impl/DataServiceImpl.java | 107 ++++++++++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 101 insertions(+), 6 deletions(-) diff --git a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/impl/DataServiceImpl.java b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/impl/DataServiceImpl.java index 01b38a5..9be30ca 100644 --- a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/impl/DataServiceImpl.java +++ b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/impl/DataServiceImpl.java @@ -5,6 +5,7 @@ import com.iailab.framework.common.util.object.ConvertUtils; import com.iailab.module.ansteel.api.dao.*; import com.iailab.module.ansteel.api.dto.*; +import com.iailab.module.ansteel.common.enums.ProcessConfDataTypeEnum; import com.iailab.module.ansteel.power.dao.*; import com.iailab.module.ansteel.power.entity.PowerCapacitorStatusEntity; import com.iailab.module.ansteel.power.entity.PowerControlDetEntity; @@ -12,6 +13,9 @@ import com.iailab.module.ansteel.power.entity.PowerNetFactorEntity; import com.iailab.module.ansteel.api.service.DataService; import com.iailab.module.ansteel.common.constant.CommonConstant; +import com.iailab.module.data.api.ind.IndItemApi; +import com.iailab.module.data.api.ind.dto.ApiIndItemQueryDTO; +import com.iailab.module.data.api.ind.dto.ApiIndItemValueDTO; import com.iailab.module.data.api.plan.PlanItemApi; import com.iailab.module.data.api.plan.dto.ApiPlanDataDTO; import com.iailab.module.data.api.point.DataPointApi; @@ -30,12 +34,16 @@ import java.util.*; import java.util.stream.Collectors; +import static com.iailab.framework.common.pojo.CommonResult.success; + @Slf4j @Service public class DataServiceImpl implements DataService { @Autowired private DataPointApi dataPointApi; + @Autowired + private IndItemApi indItemApi; @Autowired private McsApi mcsApi; @@ -105,9 +113,9 @@ @Override public List<MainProcessIndexDTO> getIndexList(Map<String, Object> params) { List<MainProcessIndexDTO> list = new ArrayList<>(); - if("day".equals(params.get("type"))) { + if ("day".equals(params.get("type"))) { list = ConvertUtils.sourceToTarget(mainProcessIndexDayDao.selectList(new QueryWrapper<>()), MainProcessIndexDTO.class); - }else if("team".equals(params.get("type"))){ + } else if ("team".equals(params.get("type"))) { list = ConvertUtils.sourceToTarget(mainProcessIndexTeamDao.selectList(new QueryWrapper<>()), MainProcessIndexDTO.class); } if (!CollectionUtils.isEmpty(list)) { @@ -136,6 +144,11 @@ @Override public Boolean useSuggest(StAlarmAndSuggestReqVO ReqVO) { return mcsApi.useSuggest(ReqVO); + } + + @Override + public Boolean ignoreSuggest(StAlarmAndSuggestReqVO ReqVO) { + return mcsApi.ignoreSuggest(ReqVO); } @Override @@ -175,9 +188,12 @@ PreDataSingleChartRespVO resultOld = mcsApi.getPreDataSingleChart(reqVO); PreDataChartRespVO result = ConvertUtils.sourceToTarget(resultOld, PreDataChartRespVO.class); PreDataViewDTO preDataView = ConvertUtils.sourceToTarget(resultOld.getDataView(), PreDataViewDTO.class); - if(trendsDataH != null) { + if (StringUtils.isNotBlank(trendsDataH)) { + // 动态上限 ApiPointValueQueryDTO pointValueQueryDTO = new ApiPointValueQueryDTO(); pointValueQueryDTO.setPointNo(trendsDataH); + pointValueQueryDTO.setStart(startTime); + pointValueQueryDTO.setEnd(endTime); List<ApiPointValueDTO> trendsDataHList = ConvertUtils.sourceToTarget(dataPointApi.queryPointHistoryValue(pointValueQueryDTO), ApiPointValueDTO.class); List<Object[]> newList = new ArrayList<>(); trendsDataHList.forEach(item -> { @@ -188,9 +204,12 @@ }); preDataView.setTrendsDataH(newList); } - if(trendsDataL != null) { + if (StringUtils.isNotBlank(trendsDataL)) { + // 动态下限 ApiPointValueQueryDTO pointValueQueryDTO = new ApiPointValueQueryDTO(); pointValueQueryDTO.setPointNo(trendsDataL); + pointValueQueryDTO.setStart(startTime); + pointValueQueryDTO.setEnd(endTime); List<ApiPointValueDTO> trendsDataLList = ConvertUtils.sourceToTarget(dataPointApi.queryPointHistoryValue(pointValueQueryDTO), ApiPointValueDTO.class); List<Object[]> newList = new ArrayList<>(); trendsDataLList.forEach(item -> { @@ -203,7 +222,6 @@ } preDataView.setPreData(resultOld.getDataView().getPreDataL()); - result.setPreDataView(preDataView); return result; } @@ -239,7 +257,7 @@ } /** - * 查询原始计划、修正计划数据 + * 查询原始计划、修正计划数据 */ @Override public Map<String, Object> getPlanDataChart(PlanDataChartReqVO reqVO) { @@ -365,4 +383,81 @@ wrapper.orderByAsc("sort"); return ConvertUtils.sourceToTarget(powerControlDetDao.selectList(wrapper), PowerControlDetDTO.class); } + + @Override + public List<Object[]> getHistoryValue(Map<String, Object> params) { + List<Object[]> dataList = new ArrayList<>(); + + if (!params.containsKey("dataType") || !params.containsKey("dataNo")) { + return dataList; + } + String dataType = params.get("dataType").toString(); + String dataNo = params.get("dataNo").toString(); + + Date startTime = null; + Date endTime = null; + Calendar calendar = Calendar.getInstance(); + calendar.set(Calendar.MILLISECOND, 0); + if (!params.containsKey("endTime") || StringUtils.isBlank(params.get("endTime").toString())) { + endTime = calendar.getTime(); + } else { + endTime = DateUtils.parse(params.get("endTime").toString(), DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND); + } + if (!params.containsKey("startTime") || StringUtils.isBlank(params.get("startTime").toString())) { + calendar.add(Calendar.DAY_OF_YEAR, -1); + startTime = calendar.getTime(); + } else { + startTime = DateUtils.parse(params.get("startTime").toString(), DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND); + } + + switch (ProcessConfDataTypeEnum.getEumByCode(dataType)) { + case DATAPOINT: + ApiPointValueQueryDTO queryParams1 = new ApiPointValueQueryDTO(); + queryParams1.setPointNo(dataNo); + queryParams1.setStart(startTime); + queryParams1.setEnd(endTime); + List<com.iailab.module.data.api.point.dto.ApiPointValueDTO> pointHisValue = dataPointApi.queryPointHistoryValue(queryParams1); + pointHisValue.forEach(item -> { + Object[] values = new Object[2]; + values[0] = DateUtils.format(item.getT(), DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND); + values[1] = new BigDecimal(item.getV()).setScale(3, BigDecimal.ROUND_HALF_UP); + dataList.add(values); + }); + break; + case IND: + log.info("IND"); + ApiIndItemQueryDTO queryParams2 = new ApiIndItemQueryDTO(); + queryParams2.setItemNo(dataNo); + queryParams2.setStart(startTime); + queryParams2.setEnd(endTime); + List<ApiIndItemValueDTO> indValues = indItemApi.queryIndItemHistoryValue(queryParams2); + indValues.forEach(item -> { + Object[] values = new Object[2]; + values[0] = item.getDataTime(); + values[1] = item.getDataValue(); + dataList.add(values); + }); + break; + default: + break; + } + return dataList; + } + + @Override + public List<PreDataViewSimpleDTO> getPreDataByOutIds(PreDataBarLineReqVO reqVO) { + PreDataBarLineRespVO preDataBarLineRespVO = mcsApi.getPreDataCharts(reqVO); + List<PreDataViewSimpleDTO> preDataViewSimpleDTOList = new ArrayList<>(); + preDataBarLineRespVO.getDataViewList().forEach(item -> { + PreDataViewSimpleDTO preDataViewSimpleDTO = new PreDataViewSimpleDTO(); + preDataViewSimpleDTO.setItemName(item.getItemName()); + preDataViewSimpleDTO.setItemId(item.getItemId()); + preDataViewSimpleDTO.setOutId(item.getOutId()); + preDataViewSimpleDTO.setPredictTime(preDataBarLineRespVO.getPredictTime()); + preDataViewSimpleDTO.setCurData(item.getCurData()); + preDataViewSimpleDTO.setRealData(item.getRealData()); + preDataViewSimpleDTOList.add(preDataViewSimpleDTO); + }); + return preDataViewSimpleDTOList; + } } \ No newline at end of file -- Gitblit v1.9.3