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/TkDealIntakeAmountDay.java |  531 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 531 insertions(+), 0 deletions(-)

diff --git a/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/rtuData/p206V1/TkDealIntakeAmountDay.java b/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/rtuData/p206V1/TkDealIntakeAmountDay.java
new file mode 100644
index 0000000..f5ff86e
--- /dev/null
+++ b/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/rtuData/p206V1/TkDealIntakeAmountDay.java
@@ -0,0 +1,531 @@
+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.DataCd83CloseVo;
+import com.dy.common.mw.protocol.p206V1.upVos.DataCd83OpenVo;
+import com.dy.common.mw.protocol.p206V1.upVos.DataCd84Vo;
+import com.dy.common.mw.protocol.p206V1.upVos.DataCdC0Vo;
+import com.dy.common.util.DateTime;
+import com.dy.pipIrrGlobal.pojoPr.PrController;
+import com.dy.pipIrrGlobal.pojoRm.RmIntakeAmountDay;
+import com.dy.pipIrrGlobal.pojoRm.RmIntakeAmountDayLast;
+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/7/8 19:00
+ * @Description 鍙栨按鍙f棩鐢ㄦ按閲忓拰婕忔崯閲�
+ */
+public class TkDealIntakeAmountDay extends TaskSurpport {
+
+    private static final Logger log = LogManager.getLogger(TkDealIntakeAmountDay.class.getName());
+
+    //绫籌D锛屼竴瀹氫笌Tree.xml閰嶇疆鏂囦欢涓厤缃竴鑷�
+    public static final String taskId = "TkDealIntakeAmountDay";
+
+    /**
+     * 鎵ц鑺傜偣浠诲姟: 鍙栨按鍙f棩鐢ㄦ按閲忓拰婕忔崯閲�
+     *
+     * @param data 闇�瑕佸鐞嗙殑鏁版嵁
+     */
+    @Override
+    public void execute(Object data) {
+        Data d = (Data) data;
+        DataV1 dV1 = (DataV1) d.getSubData();//鍓嶉潰浠诲姟宸茬粡鍒ゆ柇涓嶄负null
+        Object cdObj = dV1.subData;
+        /**
+         * 2025-01-11
+         * 鍘熸潵瀹炵幇鏈换鍔″姛鑳斤紝鏁版嵁浠�84锛�83锛孋0鍔熻兘鐮佹暟鎹腑鑾峰緱缁熻鏁版嵁锛屼絾鍚庢潵鏁版嵁涓鍔犱簡閲戦涓庡紑鍏抽榾娆℃暟锛�
+         * 浠庤�屼娇寰椾粠涓夌鏁版嵁涓粺璁℃暟鎹浉褰撳洶闅句笌鑷浉鐭涚浘锛屾墍浠ヤ慨鏀瑰疄鐜版柟寮忥紝鍙粠83鏁版嵁涓粺璁℃湰鏁版嵁锛屽苟涓斾粠鍑�
+         * 涓湀鏉ヨ繍琛屾暟鎹湅锛屽彧瑕佽澶囪兘涓婄嚎锛屽熀鏈笂鍚勭涓婃姤鏁版嵁閮借兘涓婃姤涓婃潵锛屾墍浠ユ病鏈夊繀椤讳粠84鍙奀0鏁版嵁涓粺璁℃暟鎹簡
+         * 鑷虫锛屾湰瀹炵幇鏂瑰紡涓绘案涔呭疄鐜版柟寮忥紝涓嶅啀淇敼鍥炲幓浜嗭紝瀹炶返璇佹槑锛屼互鍓嶇殑瀹炵幇鏂瑰紡鏁版嵁鏄粺璁′笉鍑嗙‘鐨勩��
+         */
+        if (cdObj != null
+                && (
+                    //cdObj instanceof DataCdC0Vo ||
+                    //cdObj instanceof DataCd84Vo ||
+                    //cdObj instanceof DataCd83OpenVo ||
+                    cdObj instanceof DataCd83CloseVo
+                )){
+            Object[] objs = this.getTaskResults(TkPreGenObjs.taskId) ;
+            DbSv sv = (DbSv)objs[0] ;
+            PrController controller = (PrController)objs[1] ;
+            try{
+                UpDataVo vo = new UpDataVo() ;
+                /*
+                if(cdObj instanceof DataCdC0Vo){
+                    vo.valueFrom((DataCdC0Vo)cdObj, null, null, null);
+                }else if(cdObj instanceof DataCd84Vo){
+                    vo.valueFrom(null, (DataCd84Vo)cdObj, null, null);
+                }else if(cdObj instanceof DataCd83OpenVo){
+                    vo.valueFrom(null,null,  (DataCd83OpenVo)cdObj,null);
+                }else */
+                if(cdObj instanceof DataCd83CloseVo){
+                    vo.valueFrom(null,null,null, (DataCd83CloseVo)cdObj);
+                }
+                this.doDeal(sv, controller, d.getRtuAddr(), dV1, vo);
+            }catch (Exception e){
+                log.error("淇濆瓨鍙栨按鍙f棩鐢ㄦ按閲忓拰婕忔崯閲忔暟鎹椂鍙戠敓寮傚父", e);
+            }
+        }
+    }
+
+    /**
+     * 涓氬姟澶勭悊
+     * @param sv             鏈嶅姟
+     * @param controller     鎺у埗鍣ㄥ璞�
+     * @param rtuAddr        鎺у埗鍣ㄥ湴鍧�
+     * @param dV1        涓婃姤鏁版嵁
+     * @param dataVo         涓婃姤鏁版嵁瀵硅薄
+     */
+    private void doDeal(DbSv sv, PrController controller, String rtuAddr, DataV1 dV1, UpDataVo dataVo) throws Exception {
+        RmIntakeAmountDayLast poLast = sv.getRmIntakeAmountLast(controller.getIntakeId());
+        if (poLast == null) {
+            //鏁版嵁搴撲腑涓嶅瓨鍦ㄨ鍙栨按鍙g殑鏃ュ彇姘撮噺鏁版嵁
+            //棣栧厛鐢熸垚鏈�鏂版暟鎹強鍘嗗彶鏁版嵁锛屽苟鍏堜繚瀛�
+            poLast = this.newRmIntakeAmountLast(controller, rtuAddr, dV1, dataVo);
+            this.newAndSaveRmIntakeAmountHistory(sv, controller, rtuAddr, dV1, dataVo, poLast);
+            sv.saveRmIntakeAmountLast(poLast);
+        } else {
+            if(DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dataVo.rtuDt).before(poLast.rtuDtLast)){
+                //RTU鏃堕挓鏃╀簬鏈湴RTU鏃堕挓锛屾槸琛ユ姤锛屼笉鐢ㄨˉ鎶ユ潵璁$畻鍙栨按鍙f棩绱鍙栨按閲忥紝鍥犱负閲囩敤鐨勬槸绱娴侀噺鐩稿樊鐨勮绠楁柟娉曪紝
+                //鍏跺疄琛ユ姤鐨勯噺鍊硷紝鍩轰簬鍓嶉潰涓婃姤鏁版嵁宸茬粡璁$畻鍖呭惈浜嗭紝鍙槸閲忓�煎綊缁撶殑鏃ユ湡涓嶆纭舰浜嗐��
+            }else if(DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dataVo.rtuDt).equals(poLast.rtuDtLast)){
+                //RTU鏃堕挓绛変簬鏈湴RTU鏃堕挓锛岄噸澶嶄笂鎶ユ暟鎹紝涓嶈繘琛屼换浣曞鐞�
+            }else{
+                //涓婅鏁版嵁涓殑鏃ユ湡鏃堕棿绗﹀悎璁$畻鐨勬潯浠�
+                if(!rtuAddr.equals(poLast.rtuAddrLast)){
+                    //鏇存崲浜嗘帶鍒跺櫒锛屽鐞嗘柟娉曪細鍙洿鎹㈡帶鍒跺櫒鍦板潃锛屼笉杩涜姘撮噺璁$畻
+                    //鍥犱负涓婅鏁版嵁涓殑鏃ユ湡鏃堕棿鏄彲杩涜璁$畻鐨�
+                    if(DateTime.dateFrom_yyyy_MM_dd1(dV1.dt).equals(poLast.dt)){
+                        //鍚屼竴澶╂暟鎹�
+                        poLast = this.updateRmIntakeAmountLastBySameDateByControllerChange(poLast, controller, rtuAddr, dV1, dataVo);
+                        RmIntakeAmountDay poHistory = null ;
+                        if(poLast.lastHistoryId != null){
+                            poHistory = sv.getRmIntakeAmountDay(poLast.lastHistoryId) ;
+                        }
+                        if(poHistory == null){
+                            this.newAndSaveRmIntakeAmountHistory(sv, controller, rtuAddr, dV1, dataVo, poLast);
+                        }else{
+                            poHistory = this.updateRmIntakeAmountBySameDateByControllerChange(poHistory, poLast, controller, rtuAddr, dV1, dataVo);
+                            sv.updateRmIntakeAmountDay(poHistory);
+                        }
+                    }else{
+                        //闈炲悓涓�澶╋紝鎵�浠ユ柊鐢熸垚涓�涓巻鍙茶褰�
+                        poLast = this.updateRmIntakeAmountLastByNewDateByControllerChange(poLast, controller, rtuAddr, dV1, dataVo);
+                        this.newAndSaveRmIntakeAmountHistory(sv, controller, rtuAddr, dV1, dataVo, poLast);
+                    }
+                }else{
+                    //鏈洿鎹㈡帶鍒跺櫒
+                    if(DateTime.dateFrom_yyyy_MM_dd1(dV1.dt).equals(poLast.dt)){
+                        //鍚屼竴澶╂暟鎹�
+                        poLast = this.updateRmIntakeAmountLastBySameDateNewData(poLast, controller, rtuAddr, dV1, dataVo);
+                        RmIntakeAmountDay poHistory = null ;
+                        if(poLast.lastHistoryId != null){
+                            poHistory = sv.getRmIntakeAmountDay(poLast.lastHistoryId) ;
+                        }
+                        if(poHistory == null){
+                            this.newAndSaveRmIntakeAmountHistory(sv, controller, rtuAddr, dV1, dataVo, poLast);
+                        }else{
+                            poHistory = this.updateRmIntakeAmountBySameDateNewData(poHistory, poLast, controller, rtuAddr, dV1, dataVo);
+                            sv.updateRmIntakeAmountDay(poHistory);
+                        }
+                    }else if(DateTime.dateFrom_yyyy_MM_dd1(dV1.dt).after(poLast.dt)){
+                        //鏂扮殑鏃ユ湡
+                        poLast = this.updateRmIntakeAmountLastByNewDateNewData(poLast, controller, rtuAddr, dV1, dataVo);
+                        this.newAndSaveRmIntakeAmountHistory(sv, controller, rtuAddr, dV1, dataVo, poLast);
+                    }else{
+                        //杩欑鎯呭喌涓嶅瓨鍦�
+                    }
+                }
+            }
+            //鏇存柊鏈�鏂版暟鎹�
+            sv.updateRmIntakeAmountLast(poLast);
+        }
+    }
+
+    /**
+     * 鐢熸垚鏂扮殑鍙栨按鍙g敤姘寸粺璁℃渶鏂拌褰�
+     * @param controller
+     * @param rtuAddr
+     * @param dV1
+     * @param cdData
+     * @return
+     * @throws Exception
+     */
+    private RmIntakeAmountDayLast newRmIntakeAmountLast(PrController controller, String rtuAddr, DataV1 dV1, UpDataVo cdData)throws Exception {
+        RmIntakeAmountDayLast po = new RmIntakeAmountDayLast() ;
+        po.intakeId = controller==null?null:controller.getIntakeId();
+        po.controllerIdLast = controller==null?null:controller.getId();
+        po.totalAmountLast = cdData.totalAmount ;
+        po.dt = DateTime.dateFrom_yyyy_MM_dd1(dV1.dt);
+        po.dtLast = DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dV1.dt);
+        po.rtuDtLast = DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(cdData.rtuDt);
+
+        po.amount = cdData.amount ;
+        po.money = cdData.money ;
+        po.times = 1 ;
+        /* 2025-01-11
+        if(cdData.isCloseValve != null && cdData.isCloseValve){
+            po.amount = cdData.amount ;
+            po.money = cdData.money ;
+            po.times = 1 ;
+        }else{
+            po.amount = 0.0D ;
+            po.money = 0.0D ;
+            po.times = 0 ;
+        }*/
+        po.rtuAddrLast = rtuAddr;
+        return po ;
+    }
+
+    /**
+     * 淇濆瓨鏂扮殑鍘嗗彶鏁版嵁璁板綍锛屽苟鎶奍D璧嬪�肩粰鏈�鏂拌褰曠殑 lastHistoryId
+     * @param sv
+     * @param controller
+     * @param rtuAddr
+     * @param dV1
+     * @param cdData
+     * @param poLast
+     * @throws Exception
+     * @return RmIntakeAmountDay
+     */
+    private RmIntakeAmountDay newAndSaveRmIntakeAmountHistory(DbSv sv, PrController controller, String rtuAddr, DataV1 dV1, UpDataVo cdData, RmIntakeAmountDayLast poLast)throws Exception {
+        RmIntakeAmountDay poHistory = new RmIntakeAmountDay() ;
+        poHistory.intakeId = controller==null?null:controller.getIntakeId();
+        poHistory.controllerIdLast = controller==null?null:controller.getId();
+        poHistory.rtuAddrLast = rtuAddr;
+        poHistory.dt = DateTime.dateFrom_yyyy_MM_dd1(dV1.dt);
+        poHistory.dtLast = DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dV1.dt);
+        poHistory.rtuDtLast = DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(cdData.rtuDt);
+        poHistory.totalAmountLast = cdData.totalAmount ;
+
+        //2025-01-11
+        if(poLast != null){
+            poHistory.amount = poLast.amount ;
+            poHistory.money = poLast.money ;
+            poHistory.times = poLast.times ;
+        }else{
+            poHistory.amount = 0.0D ;
+            poHistory.money = 0.0D ;
+            poHistory.times = 0 ;
+        }
+
+        sv.saveRmIntakeAmountDay(poHistory);
+        //鐢辨渶鏂版暟鎹寔鏈夊巻鍙叉暟鎹腑鐨勬渶鏂拌褰旾D锛屼互鏂逛究蹇�熸煡璇�
+        poLast.lastHistoryId = poHistory == null ? null: poHistory.id ;
+        return poHistory ;
+    }
+
+
+    /**
+     * 鍙栨按鍙f洿鎹簡鎺у埗鍣紝鍚屼竴澶╂暟鎹紝姝ゆ椂鍙洿鏂伴儴鍒嗗睘鎬�
+     * @param controller
+     * @param rtuAddr
+     * @param dV1
+     * @param cdData
+     * @return
+     * @throws Exception
+     */
+    private RmIntakeAmountDayLast updateRmIntakeAmountLastBySameDateByControllerChange(RmIntakeAmountDayLast lastPo, PrController controller, String rtuAddr, DataV1 dV1, UpDataVo cdData)throws Exception {
+        lastPo.intakeId = controller==null?null:controller.getIntakeId();
+        lastPo.controllerIdLast = controller==null?null:controller.getId();
+        lastPo.rtuAddrLast = rtuAddr;
+        lastPo.dt = DateTime.dateFrom_yyyy_MM_dd1(dV1.dt);
+        lastPo.dtLast = DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dV1.dt);
+        lastPo.rtuDtLast = DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(cdData.rtuDt);
+        lastPo.totalAmountLast = cdData.totalAmount ;
+        //闃�鎺у櫒鏇存崲浜嗭紝骞朵笖鏄悓涓�澶╂暟鎹�
+        //鍙湁鍏抽榾鎶ユ暟鎹紙2025-01-11锛�
+        if(lastPo.amount == null){
+            lastPo.amount = cdData.amount ;
+        }else{
+            lastPo.amount += cdData.amount ;
+        }
+        if(lastPo.money == null){
+            lastPo.money = cdData.money ;
+        }else{
+            lastPo.money += cdData.money ;
+        }
+        if(lastPo.times == null){
+            lastPo.times = 1 ;
+        }else{
+            lastPo.times += 1 ;
+        }
+        /*
+        if(cdData.isCloseValve != null && cdData.isCloseValve.booleanValue()){
+            //鏄粠鍏抽榾鎶ヤ腑寰楀埌鐨勬暟鎹�
+            if(lastPo.amount == null){
+                lastPo.amount = cdData.amount ;
+            }else{
+                lastPo.amount += cdData.amount ;
+            }
+            if(lastPo.money == null){
+                lastPo.money = cdData.money ;
+            }else{
+                lastPo.money += cdData.money ;
+            }
+            if(lastPo.times == null){
+                lastPo.times = 1 ;
+            }else{
+                lastPo.times += 1 ;
+            }
+        }else{
+            //闈炲叧闃�鎶ユ暟鎹�
+            //涓嶄綔涓�
+        }*/
+        return lastPo ;
+    }
+
+    /**
+     * 鍙栨按鍙f洿鎹簡鎺у埗鍣ㄥ湪锛屾鏃跺彧鏇存柊閮ㄥ垎灞炴��
+     * @param controller
+     * @param rtuAddr
+     * @param dV1
+     * @param cdData
+     * @return
+     * @throws Exception
+     */
+    private RmIntakeAmountDay updateRmIntakeAmountBySameDateByControllerChange(RmIntakeAmountDay po, RmIntakeAmountDayLast lastPo, PrController controller, String rtuAddr, DataV1 dV1, UpDataVo cdData)throws Exception {
+        po.intakeId = controller==null?null:controller.getIntakeId();
+        po.controllerIdLast = controller==null?null:controller.getId();
+        po.rtuAddrLast = rtuAddr;
+        po.dt = lastPo.dt ;
+        po.dtLast = lastPo.dtLast;
+        po.rtuDtLast = lastPo.rtuDtLast;
+        po.totalAmountLast = lastPo.totalAmountLast ;
+
+        //闃�鎺у櫒鏇存崲浜嗭紝骞朵笖鏄悓涓�澶╂暟鎹�
+        //鍙湁鍏抽榾鎶ユ暟鎹紙2025-01-11锛�
+        po.amount = lastPo.amount ;
+        po.money = lastPo.money ;
+        po.times = lastPo.times ;
+
+        return po ;
+    }
+
+    /**
+     * 鍙栨按鍙f洿鎹簡鎺у埗鍣紝闈炲悓涓�澶╂暟鎹紝姝ゆ椂鏇存柊閮ㄥ垎灞炴��
+     * @param controller
+     * @param rtuAddr
+     * @param dV1
+     * @param cdData
+     * @return
+     * @throws Exception
+     */
+    private RmIntakeAmountDayLast updateRmIntakeAmountLastByNewDateByControllerChange(RmIntakeAmountDayLast lastPo, PrController controller, String rtuAddr, DataV1 dV1, UpDataVo cdData)throws Exception {
+        lastPo.intakeId = controller==null?null:controller.getIntakeId();
+        lastPo.controllerIdLast = controller==null?null:controller.getId();
+        lastPo.rtuAddrLast = rtuAddr;
+        lastPo.dt = DateTime.dateFrom_yyyy_MM_dd1(dV1.dt);
+        lastPo.dtLast = DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dV1.dt);
+        lastPo.rtuDtLast = DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(cdData.rtuDt);
+        lastPo.totalAmountLast = cdData.totalAmount ;
+
+        //闃�鎺у櫒鏇存崲浜嗭紝骞朵笖鏄柊涓�澶╂暟鎹� 2025-01-11
+        lastPo.amount = cdData.amount ;
+        lastPo.money = cdData.money ;
+        lastPo.times = 1 ;
+
+        return lastPo ;
+    }
+
+
+
+    /**
+     * 鏀跺埌鍚屼竴澶╃殑鏂扮殑鏁版嵁锛岃繘琛屾洿鏂版暟鎹�
+     * @param controller
+     * @param rtuAddr
+     * @param dV1
+     * @param cdData
+     * @return
+     * @throws Exception
+     */
+    private RmIntakeAmountDayLast updateRmIntakeAmountLastBySameDateNewData(RmIntakeAmountDayLast lastPo, PrController controller, String rtuAddr, DataV1 dV1, UpDataVo cdData)throws Exception {
+        lastPo.intakeId = controller==null?null:controller.getIntakeId();
+        lastPo.controllerIdLast = controller==null?null:controller.getId();
+        lastPo.rtuAddrLast = rtuAddr;
+        //lastPo.dt = DateTime.dateFrom_yyyy_MM_dd1(dV1.dt);//鏃ユ湡娌″彉
+        lastPo.dtLast = DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dV1.dt);
+        lastPo.rtuDtLast = DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(cdData.rtuDt);
+        if(cdData.totalAmount == 0.0F){
+            //鍙戠幇闃�鎺у櫒涓�涓猙ug锛岀粡甯镐笂鎶ョ疮璁℃祦閲忎负0锛屾帹娴嬫槸闃�鎺у櫒鏈兘浠庢按琛ㄩ噰闆嗗埌鏁版嵁鏃朵細涓婃姤0鍊�
+            //杩欑鎯呭喌鏁版嵁涓嶅仛澶勭悊
+            //濡傛灉姘磋〃鍒濆畨瑁咃紝鏈繘琛岃繃浠诲姟鍙栨按锛岄偅涔堢疮璁℃祦閲忎細鏄�0锛岃繖绉嶆儏鍐靛綋bug澶勭悊涔熸棤闃�
+            //涓婇潰鏃舵爣浣滀簡鏇存柊锛屼篃姝e父锛岀浉褰撲簬鏈涓婃姤鐨勭疮璁℃祦閲忎笌涓婃涓婃姤鐨勭疮璁℃祦閲忔暟鍊肩浉绛�
+            //lastPo.totalAmountLast = lastPo.totalAmountLast ;
+            //lastPo.amount = lastPo.amount; //鏈棩鐨勬棩绱姘撮噺淇濇寔涓嶅彉
+        }else {
+            lastPo.totalAmountLast = cdData.totalAmount;
+        }
+        //鏄悓涓�澶╂暟鎹�
+        //鍙湁鍏抽榾鎶ユ暟鎹紙2025-01-11锛�
+        if(lastPo.amount == null){
+            lastPo.amount = cdData.amount ;
+        }else{
+            lastPo.amount += cdData.amount ;
+        }
+        if(lastPo.money == null){
+            lastPo.money = cdData.money ;
+        }else{
+            lastPo.money += cdData.money ;
+        }
+        if(lastPo.times == null){
+            lastPo.times = 1 ;
+        }else{
+            lastPo.times += 1 ;
+        }
+
+        /* 2025-01-11
+        Double added = cdData.totalAmount - lastPo.totalAmountLast ;
+        if(added > 0){
+            if(lastPo.amount == null){
+                lastPo.amount = added ;
+            }else{
+                lastPo.amount += added ;
+            }
+        }else{
+            //鍙兘鏄洿鎹㈡按琛ㄤ簡锛屾柊琛ㄥ簳鍊兼瘮鍘熻〃搴曞�煎皬銆�
+            //鏈缃噺鍊间笉鍙橈紝涓嬫鍐嶄笂鎶ユ椂锛屽氨鑳芥甯歌绠椾簡銆�
+            //lastPo.amount = lastPo.amount ; //鏃ョ疮璁″彇姘撮噺涓嶅彉
+        }
+
+        if(cdData.isCloseValve != null && cdData.isCloseValve.booleanValue()){
+            //鏄粠鍏抽榾鎶ヤ腑寰楀埌鐨勬暟鎹�
+            if(lastPo.money == null){
+                lastPo.money = cdData.money ;
+            }else{
+                lastPo.money += cdData.money ;
+            }
+            if(lastPo.times == null){
+                lastPo.times = 1 ;
+            }else{
+                lastPo.times += 1 ;
+            }
+        }else{
+            //闈炲叧闃�鎶ユ暟鎹�
+            //涓嶄綔涓�
+        }
+        */
+
+        return lastPo ;
+    }
+
+    /**
+     * 鍥犳敹鍒版柊鐨勪竴澶╃殑鏂扮殑鏁版嵁鍚庯紝杩涜鏇存柊鏁版嵁
+     * @param controller
+     * @param rtuAddr
+     * @param dV1
+     * @param cdData
+     * @return
+     * @throws Exception
+     */
+    private RmIntakeAmountDayLast updateRmIntakeAmountLastByNewDateNewData(RmIntakeAmountDayLast lastPo, PrController controller, String rtuAddr, DataV1 dV1, UpDataVo cdData)throws Exception {
+        lastPo.intakeId = controller==null?null:controller.getIntakeId();
+        lastPo.controllerIdLast = controller==null?null:controller.getId();
+        lastPo.rtuAddrLast = rtuAddr;
+        lastPo.dt = DateTime.dateFrom_yyyy_MM_dd1(dV1.dt);//鏃ユ湡鍙樹簡
+        lastPo.dtLast = DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dV1.dt);
+        lastPo.rtuDtLast = DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(cdData.rtuDt);
+        lastPo.totalAmountLast = cdData.totalAmount ;
+
+        //鏂扮殑涓�澶╂暟鎹� 2025-01-11
+        lastPo.amount = cdData.amount ;
+        lastPo.money = cdData.money ;
+        lastPo.times = 1 ;
+
+        /*
+        if(cdData.totalAmount == 0.0F){
+            //鍙戠幇闃�鎺у櫒涓�涓猙ug锛岀粡甯镐笂鎶ョ疮璁℃祦閲忎负0锛屾帹娴嬫槸闃�鎺у櫒鏈兘浠庢按琛ㄩ噰闆嗗埌鏁版嵁鏃朵細涓婃姤0鍊�
+            //杩欑鎯呭喌鏁版嵁涓嶅仛澶勭悊
+            //濡傛灉姘磋〃鍒濆畨瑁咃紝鏈繘琛岃繃浠诲姟鍙栨按锛岄偅涔堢疮璁℃祦閲忎細鏄�0锛岃繖绉嶆儏鍐靛綋bug澶勭悊涔熸棤闃�
+            //涓婇潰鏃舵爣浣滀簡鏇存柊锛屼篃姝e父锛岀浉褰撲簬鏈涓婃姤鐨勭疮璁℃祦閲忎笌涓婃涓婃姤鐨勭疮璁℃祦閲忔暟鍊肩浉绛�
+            //lastPo.totalAmountLast = lastPo.totalAmountLast ;
+            lastPo.amount = 0.0D; //鏂扮殑涓�澶╃殑鏃ョ疮璁℃按閲忕疆0
+        }else{
+            Double added = cdData.totalAmount - lastPo.totalAmountLast ;
+            if(added > 0){
+                //鏂扮殑涓�澶╃殑澶勭悊鏂瑰紡涓庡悓涓�澶╃殑澶勭悊鏂瑰紡涓嶄竴鏍�
+                lastPo.amount = added;
+            }else{
+                //鍙兘鏄洿鎹㈡按琛ㄤ簡锛屾柊琛ㄥ簳鍊兼瘮鍘熻〃搴曞�煎皬銆�
+                //鏈缃�0锛屼笅娆″啀涓婃姤鏃讹紝灏辫兘姝e父璁$畻浜嗐��
+                lastPo.amount = 0.0D; //鏃ョ疮璁℃按閲忓綊0
+            }
+        }
+        if(cdData.isCloseValve != null && cdData.isCloseValve.booleanValue()){
+            //鏄粠鍏抽榾鎶ヤ腑寰楀埌鐨勬暟鎹�
+            lastPo.money = cdData.money ;
+            lastPo.times = 1 ;
+        }else{
+            //闈炲叧闃�鎶ユ暟鎹�
+            //涓嶄綔涓�
+        }
+        */
+
+        return lastPo ;
+    }
+
+
+    /**
+     * 鏇存柊鍘嗗彶璁板綍
+     * @param controller
+     * @param rtuAddr
+     * @param dV1
+     * @param cdData
+     * @return
+     * @throws Exception
+     */
+    private RmIntakeAmountDay updateRmIntakeAmountBySameDateNewData(RmIntakeAmountDay po, RmIntakeAmountDayLast lastPo, PrController controller, String rtuAddr, DataV1 dV1, UpDataVo cdData)throws Exception {
+        po.intakeId = controller==null?null:controller.getIntakeId();
+        po.controllerIdLast = controller==null?null:controller.getId();
+        po.rtuAddrLast = rtuAddr;
+        po.dt = lastPo.dt ;
+        po.dtLast = lastPo.dtLast;
+        po.rtuDtLast = lastPo.rtuDtLast;
+        po.totalAmountLast = lastPo.totalAmountLast ;
+
+        po.amount = lastPo.amount ;//姝ゆ椂lastPo.amount宸茬粡澧炲姞涓婁簡澧為噺
+        po.money = lastPo.money ;//姝ゆ椂lastPo.money宸茬粡澧炲姞涓婁簡澧為噺
+        po.times = lastPo.times ;//姝ゆ椂lastPo.times宸茬粡澧炲姞涓婁簡澧為噺
+
+        return po ;
+    }
+
+
+    public class UpDataVo{
+        public Double totalAmount; //绱娴侀噺锛�5瀛楄妭BCD鐮侊紝鍙栧�艰寖鍥�0~9999999999锛屽崟浣嶄负m3銆�
+        public Double amount; //鍐滄埛鐢ㄦ按閲�
+        public Double money ;//鍐滄埛娑堣垂閲戦
+        public Boolean isCloseValve ;//鏄惁鏄叧闃�涓婃姤
+        public String rtuDt ;//鎺у埗鍣ㄦ椂閽�
+
+        public void valueFrom(DataCdC0Vo voC0, DataCd84Vo vo84, DataCd83OpenVo vo83Op, DataCd83CloseVo vo83Cl){
+            /*
+            if(voC0 != null){
+                this.totalAmount = voC0.totalAmount ;
+                this.rtuDt = voC0.rtuDt ;
+            }else if(vo84 != null){
+                this.totalAmount = vo84.totalAmount ;
+                this.rtuDt = vo84.rtuDt ;
+            }else if(vo83Op != null){
+                this.totalAmount = vo83Op.totalAmount ;
+                this.rtuDt = vo83Op.rtuDt ;
+            }else if(vo83Cl != null){ */
+                this.totalAmount = vo83Cl.totalAmount ;
+                this.amount = vo83Cl.thisAmount ;
+                this.money = vo83Cl.thisMoney ;
+                this.isCloseValve = true ;
+                this.rtuDt = vo83Cl.rtuDt ;
+            /*} */
+        }
+
+    }
+
+
+
+}

--
Gitblit v1.8.0