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