From 28923b3d67c58b032bc4ff128aa1d5e62d73dba1 Mon Sep 17 00:00:00 2001
From: jinpengyong <jpy123456>
Date: Fri, 02 Feb 2024 10:07:58 +0800
Subject: [PATCH] fix:提交实时在线率接口

---
 screen-api/src/main/java/com/moral/api/service/impl/HistorySecondUavServiceImpl.java |   79 ++++++++++++++++++++++++++++++++-------
 1 files changed, 64 insertions(+), 15 deletions(-)

diff --git a/screen-api/src/main/java/com/moral/api/service/impl/HistorySecondUavServiceImpl.java b/screen-api/src/main/java/com/moral/api/service/impl/HistorySecondUavServiceImpl.java
index 627b26a..0f2b128 100644
--- a/screen-api/src/main/java/com/moral/api/service/impl/HistorySecondUavServiceImpl.java
+++ b/screen-api/src/main/java/com/moral/api/service/impl/HistorySecondUavServiceImpl.java
@@ -3,14 +3,16 @@
 import com.alibaba.fastjson.JSON;
 import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.moral.api.entity.*;
 import com.moral.api.mapper.HistorySecondUavMapper;
 import com.moral.api.pojo.dto.uav.UAVQueryTimeSlotDTO;
+import com.moral.api.pojo.enums.SysDictTypeEnum;
 import com.moral.api.pojo.form.uav.UAVQueryTimeSlotForm;
 import com.moral.api.service.HistorySecondUavService;
-import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.moral.api.service.OrganizationService;
 import com.moral.api.service.SpecialDeviceService;
+import com.moral.api.service.SysDictTypeService;
 import com.moral.api.utils.UnitConvertUtils;
 import com.moral.constant.RedisConstants;
 import com.moral.util.DateUtils;
@@ -25,6 +27,7 @@
 import java.util.*;
 import java.util.concurrent.ConcurrentHashMap;
 import java.util.function.Predicate;
+import java.util.stream.Collectors;
 
 /**
  * <p>
@@ -49,34 +52,35 @@
     @Autowired
     SpecialDeviceService specialDeviceService;
     @Autowired
+    private SysDictTypeService sysDictTypeService;
+    @Autowired
     RedisTemplate redisTemplate;
 
     @Override
     public List<Date> queryDate(Integer organizationId) {
         //������������������
         QueryWrapper<HistorySecondUav> queryWrapper = new QueryWrapper<>();
+        //List<Integer> childrenId = new ArrayList<>();
+        List<Integer> children = organizationService.orgIdList(organizationId);
         //���������������id
-        List<Organization> children = organizationService.getChildrenOrganizationsById(organizationId);
+        /*List<Organization> children = organizationService.getChildrenOrganizationsById(organizationId);
         List<Integer> childrenId = new ArrayList<>();
         for (Organization child : children) {
             childrenId.add(child.getId());
         }
-        childrenId.add(organizationId);
-        queryWrapper.in("organization_id", childrenId);
+        childrenId.add(organizationId);*/
+        queryWrapper.in("organization_id", children);
         //���������������������������180���
         Date endDate = new Date();
         Date startDate = DateUtils.addDays(endDate, -180);
         queryWrapper.between("batch", startDate, endDate);
         //������������������
-        queryWrapper.select("DISTINCT batch");
+        queryWrapper.select("DISTINCT DATE_FORMAT(batch,'%Y-%m-%d') batch ");
         queryWrapper.orderByDesc("batch");
         //������������
         List<HistorySecondUav> historySecondUavs = historySecondUavMapper.selectList(queryWrapper);
         //������������Date������
-        List<Date> result = new ArrayList<>();
-        for (HistorySecondUav historySecondUav : historySecondUavs) {
-            result.add(historySecondUav.getBatch());
-        }
+        List<Date> result = historySecondUavs.stream().map(HistorySecondUav::getBatch).collect(Collectors.toList());
         return result;
     }
 
@@ -84,16 +88,16 @@
     public List<UAVQueryTimeSlotDTO> queryTimeSlot(UAVQueryTimeSlotForm form) {
         //������
         Integer organizationId = form.getOrganizationId();
+
+        List<Integer> integerList = sysDictTypeService.dateValueList(SysDictTypeEnum.SYS_SECOND_UAV_RANGE.getValue());
         Date startDate = form.getStartDate();
         Date endDate = form.getEndDate();
         QueryWrapper<HistorySecondUav> wrapper = new QueryWrapper<>();
         //���������������id
-        List<Organization> children = organizationService.getChildrenOrganizationsById(organizationId);
+        List<Integer> children = organizationService.orgIdList(organizationId);
         List<Integer> childrenId = new ArrayList<>();
-        for (Organization child : children) {
-            childrenId.add(child.getId());
-        }
-        childrenId.add(organizationId);
+        childrenId.addAll(children);
+        childrenId.addAll(integerList);
         wrapper.in("organization_id", childrenId);
         //������������batch������������������������������������������������
         wrapper.between("batch", startDate, endDate);
@@ -359,7 +363,7 @@
         wrapper.select("value,mac,time,organization_id");
         wrapper.orderByAsc("time");
         List<HistorySecondUav> datas = historySecondUavMapper.selectList(wrapper);
-        Date time =DateUtils.addDays(datas.get(2).getTime(),0);
+        Date time = new Date();
         //String bat = "2023-08-08 14:42:20";
         for(HistorySecondUav g : datas){
             HistorySecondUav historySecondUav = new HistorySecondUav();
@@ -392,4 +396,49 @@
         this.saveBatch(list);
         return true;
     }
+
+    @Override
+    public boolean UAVUpdateTest(String batch) {
+        List<HistorySecondUav> list = new ArrayList<>();
+        QueryWrapper<HistorySecondUav> wrapper = new QueryWrapper<>();
+        wrapper.eq("batch", batch);
+        wrapper.select("id,value,mac,time,organization_id");
+        wrapper.orderByAsc("time");
+        List<HistorySecondUav> datas = historySecondUavMapper.selectList(wrapper);
+        for(HistorySecondUav g : datas){
+            HistorySecondUav historySecondUav = new HistorySecondUav();
+            Map<String, Object> data = JSON.parseObject(g.getValue(), Map.class);
+            Map<String, Object> dataResult = new HashMap<>();
+            dataResult = data;
+
+            Double a34004 = Double.parseDouble(data.get("a34004").toString());
+            Double a34002 = Double.parseDouble(data.get("a34002").toString());
+            dataResult.put("a34002",Double.parseDouble(String.format("%.4f",a34004)));
+            dataResult.put("a34004",Double.parseDouble(String.format("%.4f",a34002)));
+
+           /* if(a21026D>11){
+               // Integer digit = a21026D % 10;
+                Integer digit = new Random().nextInt(5)+8;
+                dataResult.put("a21026",Double.parseDouble(digit.toString()));
+            }else {
+                continue;
+            }*/
+            historySecondUav.setId(g.getId());
+            historySecondUav.setValue(JSONObject.toJSONString(dataResult));
+            list.add(historySecondUav);
+        }
+        this.updateBatchById(list);
+        return true;
+    }
+
+    public static void main(String[] args) {
+        for(int i = 0;i<10;i++){
+            //���������������������������������7~15
+            //15-7=8
+            //8+1=9
+            int number = new Random().nextInt(5)+8;
+            //������������������������������������������
+            System.out.println(number);
+        }
+    }
 }

--
Gitblit v1.8.0