From 656aa4f953eb52502a6414965e46642c31b6e8ee Mon Sep 17 00:00:00 2001 From: liurunyu <lry9898@163.com> Date: 星期二, 29 四月 2025 15:33:09 +0800 Subject: [PATCH] 设备会在多种功能码上报数据中携带报警与状态数据,这样数据库保存设备报警与状态数据可能很多,为此修改逻辑,当前实现为一设备一个小时内只保存一条报警与状态数据。 --- pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/rtuData/p206V1/TkDealOnHourReport.java | 125 +++++++++++++++++++++++++++++++++++++++++ 1 files changed, 125 insertions(+), 0 deletions(-) diff --git a/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/rtuData/p206V1/TkDealOnHourReport.java b/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/rtuData/p206V1/TkDealOnHourReport.java new file mode 100644 index 0000000..3ac3c11 --- /dev/null +++ b/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/rtuData/p206V1/TkDealOnHourReport.java @@ -0,0 +1,125 @@ +package com.dy.rtuMw.server.rtuData.p206V1; + +import com.dy.common.mw.protocol.Data; +import com.dy.common.mw.protocol.p206V1.DataV1; +import com.dy.common.mw.protocol.p206V1.upVos.DataCdC0Vo; +import com.dy.pipIrrGlobal.pojoPr.PrController; +import com.dy.pipIrrGlobal.pojoRm.RmOnHourReportHistory; +import com.dy.pipIrrGlobal.pojoRm.RmOnHourReportLast; +import com.dy.rtuMw.server.ServerProperties; +import com.dy.rtuMw.server.forMs.SendMsCache; +import com.dy.rtuMw.server.rtuData.TaskSurpport; +import com.dy.rtuMw.server.rtuData.dbSv.DbSv; +import org.apache.logging.log4j.LogManager; +import org.apache.logging.log4j.Logger; + +/** + * @Author liurunyu + * @Date 2024/1/16 14:11 + * @LastEditTime 2024/1/16 14:11 + * @Description 鎺у埗鍣ㄨ嚜鎶ュ疄鏃舵暟鎹紙鍔熻兘鐮佷负C0锛夛紙瀹氱偣涓婃姤锛� + */ +public class TkDealOnHourReport extends TaskSurpport { + + private static final Logger log = LogManager.getLogger(TkDealOnHourReport.class.getName()) ; + + //绫籌D锛屼竴瀹氫笌Tree.xml閰嶇疆鏂囦欢涓厤缃竴鑷� + public static final String taskId = "TkDealOnHourReport" ; + + /** + * 鎵ц鑺傜偣浠诲姟锛氭帶鍒跺櫒鑷姤鏁版嵁锛堝姛鑳界爜涓篊0锛� + * @param data 闇�瑕佸鐞嗙殑鏁版嵁 + */ + @Override + public void execute(Object data) { + Data d = (Data) data; + DataV1 dV1 = (DataV1) d.getSubData();//鍓嶉潰浠诲姟宸茬粡鍒ゆ柇涓嶄负null + Object cdObj = dV1.subData; + if (cdObj != null && cdObj instanceof DataCdC0Vo){ + Object[] objs = this.getTaskResults(TkPreGenObjs.taskId) ; + DbSv sv = (DbSv)objs[0] ; + PrController controller = (PrController)objs[1] ; + try{ + this.doDeal(sv, controller, d.getRtuAddr(), dV1, (DataCdC0Vo)cdObj); + }catch (Exception e){ + log.error("淇濆瓨鎺у埗鍣ㄥ畾鐐逛笂鎶ユ暟鎹椂鍙戠敓寮傚父", e); + } + } + } + /** + * 澶勭悊闃�涓婃姤鏁版嵁 + * @param sv 鏈嶅姟 + * @param controller 鎺у埗鍣ㄥ璞� + * @param rtuAddr 鎺у埗鍣ㄥ湴鍧� + * @param cdData 鍗忚鏁版嵁 + * @param cdData 鍔熻兘鏁版嵁 + */ + private void doDeal(DbSv sv, PrController controller, String rtuAddr, DataV1 dV1, DataCdC0Vo cdData) throws Exception { + this.saveOrUpdateLast(sv, controller, rtuAddr, dV1, cdData); + this.saveHistory(sv, controller, rtuAddr, dV1, cdData); + } + /** + * 淇濆瓨鑷姤鏈�鏂版暟鎹� + * @param sv 鏈嶅姟 + * @param controller 鎺у埗鍣ㄥ璞� + * @param rtuAddr 鎺у埗鍣ㄥ湴鍧� + * @param cdData 鑷姤鏁版嵁瀵硅薄 + */ + private void saveOrUpdateLast(DbSv sv, PrController controller, String rtuAddr, DataV1 dV1, DataCdC0Vo cdData) throws Exception { + RmOnHourReportLast po = sv.getRmOnHourReportLast(controller.getIntakeId()) ; + if(po == null){ + po = new RmOnHourReportLast(); + po.controllerId = controller==null?null:controller.getId(); + po.intakeId = controller==null?null:controller.getIntakeId(); + po.rtuAddr = rtuAddr; + po.valueFrom(dV1, cdData); + sv.saveRmOnHourReportLast(po) ; + if(po.lossAmount >= ServerProperties.intakeAlarmLossMinValue){ + this.sendMessage(controller, po.lossAmount); + } + }else{ + po.controllerId = controller==null?null:controller.getId(); + po.intakeId = controller==null?null:controller.getIntakeId(); + po.valueFrom(dV1, cdData); + sv.updateRmOnHourReportLast(po); + if(po.lossAmount >= ServerProperties.intakeAlarmLossMinValue){ + this.sendMessage(controller, po.lossAmount); + } + } + } + + + /** + * 淇濆瓨鎴栨洿鏂版帶鍒跺櫒璇ヤ笂鎶ュ巻鍙叉暟鎹� + * @param sv 鏈嶅姟bean + * @param controller 鎺у埗鍣ㄥ璞� + * @param rtuAddr 鎺у埗鍣ㄥ湴鍧� + * @param dV1 鍗忚鏁版嵁 + * @param cdData 鍔熻兘鏁版嵁 + */ + private void saveHistory(DbSv sv, PrController controller, String rtuAddr, DataV1 dV1, DataCdC0Vo cdData)throws Exception { + RmOnHourReportHistory po = new RmOnHourReportHistory(); + po.controllerId = controller==null?null:controller.getId(); + po.intakeId = controller==null?null:controller.getIntakeId(); + po.rtuAddr = rtuAddr; + po.valueFrom(dV1, cdData); + sv.saveRmOnHourReportHistory(po); ; + } + + + + /** + * 鍚戦拤閽夊彂閫佹秷鎭� + * @param controller + */ + private void sendMessage(PrController controller, Double lossAmount){ + String ms = "鍙栨按鍙b��" + controller.getIntakeName() + "鈥濇紡姘存姤璀︼紝浠婃棩婕忔崯閲�" + lossAmount + "绔嬫柟绫�"; + try{ + SendMsCache.cacheMs(ms); + }catch (Exception e){ + log.error("缂撳瓨閽夐拤娑堟伅寮傚父锛�", e); + } + } + +} + -- Gitblit v1.8.0