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); 
 | 
    } 
 | 
  
 | 
  
 | 
} 
 |