| package com.dy.rtuMw.server.rtuData.pSdV1; | 
|   | 
| import com.dy.common.mw.protocol4Mqtt.MqttSubMsg; | 
| import com.dy.common.mw.protocol4Mqtt.pSdV1.upVos.ManureVo; | 
| import com.dy.pipIrrGlobal.pojoPr.PrStManure; | 
| import com.dy.rtuMw.server.rtuData.dbSv.DbSv; | 
| import org.apache.logging.log4j.LogManager; | 
| import org.apache.logging.log4j.Logger; | 
|   | 
| /** | 
|  * @Author: liurunyu | 
|  * @Date: 2025/7/31 16:42 | 
|  * @Description | 
|  */ | 
| public class TkDealManureLastSdV1 extends TkDealManureSdV1 { | 
|   | 
|     private static Logger log = LogManager.getLogger(TkDealManureLastSdV1.class.getName()); | 
|   | 
|     //类ID,一定与Tree.xml配置文件中配置一致 | 
|     public static final String taskId = "TkDealManureLastSdV1"; | 
|   | 
|     /** | 
|      * 执行节点任务 | 
|      * | 
|      * @param data 需要处理的数据 | 
|      */ | 
|     @Override | 
|     public void execute(Object data) { | 
|         //前面的任务已经判断了data不为空且为水肥数据 | 
|         MqttSubMsg msg = (MqttSubMsg) data; | 
|         ManureVo stVo = (ManureVo) msg.vo4Up; | 
|         Object[] objs = this.getTaskResults(TkPreGenObjs4ManureSdV1.taskId); | 
|         DbSv sv = (DbSv) objs[0]; | 
|         PrStManure stPo = (PrStManure) objs[1]; | 
|         try{ | 
|             this.doDeal(sv, stPo, msg, stVo); | 
|         }catch (Exception e){ | 
|             log.error("保存水肥数据时发生异常", e); | 
|         } | 
|     } | 
|   | 
|     /** | 
|      * 处理上行消息数据 | 
|      * @param sv 服务 | 
|      * @param stPo 实体对象 | 
|      * @param msg 上行的订阅消息 | 
|      * @param stVo 上行的设备数据 | 
|      */ | 
|     private void doDeal(DbSv sv, | 
|                         PrStManure stPo, | 
|                         MqttSubMsg msg, | 
|                         ManureVo stVo) throws Exception { | 
|         //2025-07-31 引处数据会很频繁,所以不在钉钉发消息,再说钉钉不叫频繁发消息 | 
|         this.saveOrUpdateLast(sv, stPo, msg, stVo, null, false); | 
|     } | 
|   | 
|   | 
| } |