From 0d32e015e87082a0b4411341b5be647979fd5f9c Mon Sep 17 00:00:00 2001
From: whyclxw <810412026@qq.com>
Date: 星期四, 26 六月 2025 16:57:02 +0800
Subject: [PATCH] 实时数据曲线统计-核容设备实时推送

---
 src/main/java/com/whyc/service/BattRtstateService.java |   36 ++++++++++++++++++++++++++++++++++++
 1 files changed, 36 insertions(+), 0 deletions(-)

diff --git a/src/main/java/com/whyc/service/BattRtstateService.java b/src/main/java/com/whyc/service/BattRtstateService.java
index d3af52f..c62fac5 100644
--- a/src/main/java/com/whyc/service/BattRtstateService.java
+++ b/src/main/java/com/whyc/service/BattRtstateService.java
@@ -5,12 +5,19 @@
 import com.whyc.constant.DevStateEnum;
 import com.whyc.dto.Real.PwrHisRealDcoutInDto;
 import com.whyc.dto.Real.RealDateDTO;
+import com.whyc.dto.RealDataStatic.ResRealDataAc;
+import com.whyc.dto.RealDataStatic.SticRealDataAc;
 import com.whyc.dto.Response;
 import com.whyc.mapper.BattRtstateMapper;
 import com.whyc.pojo.db_ram_db.BattRtstate;
+import com.whyc.pojo.db_ram_db.PwrdevAcdcdata;
+import com.whyc.util.ActionUtil;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 
+import java.lang.reflect.Field;
+import java.util.HashMap;
+import java.util.List;
 import java.util.Map;
 
 @Service
@@ -36,4 +43,33 @@
         RealDateDTO hrDto=mapper.getBattRealHr(battgroupId);
         return hrDto;
     }
+    //瀹炴椂鏁版嵁缁熻鏇茬嚎-鏍稿璁惧
+    public ResRealDataAc getSticRealDataAc(SticRealDataAc realDataAc) throws NoSuchFieldException, IllegalAccessException {
+        Integer battgroupId=realDataAc.getBattgroupId();
+        Map<String, List<String>> propertyInfo=realDataAc.getPropertyInfo();
+        QueryWrapper wrapper=new QueryWrapper();
+        wrapper.eq("battgroup_id",battgroupId);
+        wrapper.last("limit 1");
+        BattRtstate batt=mapper.selectOne(wrapper);
+        ResRealDataAc data=new ResRealDataAc();
+        if(batt!=null){
+            data.setRecordDatetime(batt.getRecDatetime());
+            Map<String, Map<String,Float>>dataMap=new HashMap<>();
+            for (Map.Entry<String, List<String>> entry : propertyInfo.entrySet()) {
+                String key = entry.getKey();
+                List<String> valueList = entry.getValue();
+                Map<String,Float> propertyMap=new HashMap<>();
+                for (String value : valueList) {
+                    String propertyName = ActionUtil.toCamelCase(value);
+                    Field field = BattRtstate.class.getDeclaredField(propertyName);
+                    field.setAccessible(true); // 濡傛灉瀛楁鏄鏈夌殑锛岄渶瑕佽缃负鍙闂�
+                    Float propertyValue = (Float) field.get(batt);
+                    propertyMap.put(value,propertyValue);
+                }
+                dataMap.put(key,propertyMap);
+            }
+            data.setPropertyInfo(dataMap);
+        }
+        return data;
+    }
 }
\ No newline at end of file

--
Gitblit v1.9.1