From 3d665d84b1a4ffd6749ca9354247838ce0622f4b Mon Sep 17 00:00:00 2001
From: jinpengyong <jpy123456>
Date: Tue, 13 Dec 2022 13:47:53 +0800
Subject: [PATCH] 修改sql语句问题
---
screen-api/src/main/java/com/moral/api/kafka/consumer/SecondDataConsumer.java | 44 +++++++++++++++++++++++++++-----------------
1 files changed, 27 insertions(+), 17 deletions(-)
diff --git a/screen-api/src/main/java/com/moral/api/kafka/consumer/SecondDataConsumer.java b/screen-api/src/main/java/com/moral/api/kafka/consumer/SecondDataConsumer.java
index 52799aa..0ae5b3f 100644
--- a/screen-api/src/main/java/com/moral/api/kafka/consumer/SecondDataConsumer.java
+++ b/screen-api/src/main/java/com/moral/api/kafka/consumer/SecondDataConsumer.java
@@ -4,8 +4,10 @@
import com.moral.api.entity.Device;
import com.moral.api.entity.Sensor;
import com.moral.api.entity.UnitConversion;
+import com.moral.api.utils.AdjustDataUtils;
+import com.moral.api.utils.UnitConvertUtils;
import com.moral.api.websocket.SingleDeviceServer;
-import com.moral.util.UnitConvertUtils;
+import lombok.extern.slf4j.Slf4j;
import org.apache.kafka.clients.consumer.Consumer;
import org.apache.kafka.clients.consumer.ConsumerRecord;
import org.apache.kafka.common.TopicPartition;
@@ -14,6 +16,7 @@
import org.springframework.stereotype.Component;
import org.springframework.util.ObjectUtils;
+import java.math.BigDecimal;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
@@ -27,22 +30,27 @@
* @Version TODO
**/
@Component
+@Slf4j
public class SecondDataConsumer implements ConsumerSeekAware {
- @KafkaListener(topics = "second_data", groupId = "SecondsDataGroup998")
+ @KafkaListener(containerFactory = "secondDataListenerFactory", topics = "second_data")
public void listen(ConsumerRecord<String, String> record, Consumer consumer) throws Exception {
String messageStr = record.value();
Map<String, Object> message = (Map<String, Object>) JSON.parse(messageStr);
CopyOnWriteArraySet<SingleDeviceServer> sockets = SingleDeviceServer.sockets;
for (SingleDeviceServer socket : sockets) {
- //���������������������������socket
+ //���������������������������socket
String messageMac = (String) message.get("mac");
String mac = socket.getMac();
- if(!mac.equals(messageMac))
- return;
+ if (!mac.equalsIgnoreCase(messageMac))
+ continue;
//������������������
- Map<String, Device> devicesInfo = socket.getDevicesInfo();
- Device device = devicesInfo.get(mac);
+ Device device = socket.getDeviceAlarmInfo();
+ Map<String, Object> adjustFormula = socket.getAdjustFormula();
+ Map<String, Object> regionAqi = socket.getRegionAqi();
+ //������������
+ if(adjustFormula!=null)
+ message = AdjustDataUtils.adjust(message,adjustFormula,regionAqi);
//������������������������
Map<String, Object> resultMessgae = new HashMap<>();
//������������
@@ -53,8 +61,13 @@
String showUnitKey = sensor.getShowUnitKey();
String unitKey = sensor.getUnitKey();
String unit = sensor.getUnit();
- String sourceData = String.valueOf(message.get(code));
- //������������
+ Object value = message.get(code);
+ if(value==null)
+ continue;
+ Double sourceDataD = Double.valueOf(String.valueOf(value));
+ BigDecimal bg = new BigDecimal(sourceDataD);
+ bg = bg.setScale(2, BigDecimal.ROUND_FLOOR);
+ String sourceData = bg.toString();
//������������
if (!unitKey.equals(showUnitKey)) {//������������������������������������������������������������
String formula = sensor.getFormula();
@@ -69,21 +82,18 @@
//������������
String resultData = UnitConvertUtils.calculate(sourceData, formula);
if (resultData != null) {
- resultData+=showUnit;
- }else{//���������������������������null���������������������������������������������������������������
- resultData = sourceData+unit;
+ resultData += showUnit;
+ } else {//���������������������������null���������������������������������������������������������������
+ resultData = sourceData + unit;
}
resultMessgae.put(sensor.getCode(), resultData);
} else {
//������������
- sourceData += showUnit;
+ if(!showUnit.equals("���������"))
+ sourceData = sourceData + " " + showUnit;
resultMessgae.put(sensor.getCode(), sourceData);
}
}
- resultMessgae.put("DataTime",message.get("DataTime"));
- resultMessgae.put("time",message.get("time"));
- resultMessgae.put("time1",message.get("time1"));
- resultMessgae.put("serverTime",System.currentTimeMillis());
socket.sendMessage(JSON.toJSONString(resultMessgae));
}
}
--
Gitblit v1.8.0