From c9dd12a0042b50af36edf2ae710d33430542385d Mon Sep 17 00:00:00 2001 From: dengzedong <dengzedong@email> Date: 星期二, 24 十二月 2024 10:15:43 +0800 Subject: [PATCH] 预测值 开始时间计算bug,数据补全bug --- iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/plan/item/collection/PlanItemCollector.java | 50 +++++++++++++++++++++++++++++++++++--------------- 1 files changed, 35 insertions(+), 15 deletions(-) diff --git a/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/plan/item/collection/PlanItemCollector.java b/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/plan/item/collection/PlanItemCollector.java index e8f862b..4e116ea 100644 --- a/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/plan/item/collection/PlanItemCollector.java +++ b/iailab-module-data/iailab-module-data-biz/src/main/java/com/iailab/module/data/plan/item/collection/PlanItemCollector.java @@ -34,8 +34,6 @@ public List<PlanItemValueVO> queryValue(String itemNo, Date startTime, Date endTime) { List<PlanItemValueVO> result = new ArrayList<>(); PlanItemEntity itemEntity = planItemService.getInfoByNo(itemNo); - Map<String, Object> params = new HashMap<String, Object>(); - PlanDataSetEntity dataSet = planDataSetService.get(itemEntity.getDataSet()); if (dataSet == null) { log.warn("数据集不能为空"); @@ -45,24 +43,14 @@ log.warn("数据源不能为空"); return null; } + Map<String, Object> params = getSqlParams(dataSet, startTime, endTime); DataContextHolder.setDataSourceId(Long.valueOf(dataSet.getDataSource())); - - params.put("selectSql", " plan_t.start_time, plan_t.end_time"); - params.put("viewSql", dataSet.getQuerySql()); - StringBuilder whereSql = new StringBuilder(); - String startStr = DateUtils.format(startTime, DateUtils.DATE_NUMBER_PATTERN); - String endStr = DateUtils.format(endTime, DateUtils.DATE_NUMBER_PATTERN); - whereSql.append(" plan_t.start_time <= " ) - .append(endStr) - .append(" and plan_t.end_time >= ") - .append(startStr); - params.put("whereSql", whereSql.toString()); List<PlanItemDataVO> dataList = planItemService.getSourceValue(params); Calendar calendar = Calendar.getInstance(); calendar.setTime(startTime); - int dataLength = (int)((endTime.getTime() - startTime.getTime()) / (1000 * 60)) + 1; - for (int i = 0; i < dataLength; i ++) { + int dataLength = (int) ((endTime.getTime() - startTime.getTime()) / (1000 * 60)) + 1; + for (int i = 0; i < dataLength; i++) { PlanItemValueVO itemValue = new PlanItemValueVO(); Date dataTime = calendar.getTime(); itemValue.setDataTime(dataTime); @@ -82,4 +70,36 @@ } return result; } + + public List<PlanItemDataVO> getSourceValue(String itemNo, Date startTime, Date endTime) { + PlanItemEntity itemEntity = planItemService.getInfoByNo(itemNo); + PlanDataSetEntity dataSet = planDataSetService.get(itemEntity.getDataSet()); + if (dataSet == null) { + log.warn("数据集不能为空"); + return null; + } + if (StringUtils.isEmpty(dataSet.getDataSource())) { + log.warn("数据源不能为空"); + return null; + } + Map<String, Object> params = getSqlParams(dataSet, startTime, endTime); + return planItemService.getSourceValue(params); + } + + private Map<String, Object> getSqlParams(PlanDataSetEntity dataSet, Date startTime, Date endTime) { + Map<String, Object> params = new HashMap<String, Object>(); + params.put("selectSql", " plan_t.start_time, plan_t.end_time"); + params.put("viewSql", dataSet.getQuerySql()); + StringBuilder whereSql = new StringBuilder(); + String startStr = DateUtils.format(startTime, DateUtils.DATE_NUMBER_PATTERN); + String endStr = DateUtils.format(endTime, DateUtils.DATE_NUMBER_PATTERN); + whereSql.append(" plan_t.start_time <= '") + .append(endStr) + .append("'") + .append(" and plan_t.end_time >= '") + .append(startStr) + .append("'"); + params.put("whereSql", whereSql.toString()); + return params; + } } \ No newline at end of file -- Gitblit v1.9.3