| | |
| | | sv.saveRmOpenCloseValveLast(poLast); |
| | | }else{ |
| | | //数据库中存在该控制器的开关阀数据 |
| | | if(poLast.closeDt != null && poLast.clIcCardAddr != null && poLast.clIcCardNo != null){ |
| | | if(poLast.closeDt.equals(DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dataCd85Vo.endDt)) |
| | | if(poLast.clOrderNo != null && poLast.clIcCardAddr != null && poLast.clIcCardNo != null){ |
| | | if(poLast.clOrderNo.equals(dataCd85Vo.orderNo) |
| | | && poLast.clIcCardAddr.equals(dataCd85Vo.icCardAddr) |
| | | && poLast.clIcCardNo.equals(dataCd85Vo.icCardNo)){ |
| | | //重复上报,原因是下行数据处理慢了,就重复上报了 |
| | |
| | | if(poLast.lastHistoryId != null){ |
| | | poHistory = sv.getRmOpenCloseValveHistory(poLast.lastHistoryId) ; |
| | | if(poHistory != null){ |
| | | if(poHistory.openDt != null){ |
| | | //上面已经判断了poLast.openDt == null,所以此处一般会是poHistory.openDt != null |
| | | if(poHistory.openDt.equals(DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dataCd85Vo.startDt))){ |
| | | if(poHistory.opOrderNo != null){ |
| | | if(poHistory.opOrderNo.equals(dataCd85Vo.orderNo)){ |
| | | //匹配成功 |
| | | //当前关阀是原记录中开阀的对应关阀 |
| | | this.updateCloseValve(clientVo, controller, rtuAddr, poLast, poHistory, dV202404, dataCd85Vo, false) ; |
| | | sv.updateRmOpenCloseValveHistory(poHistory); |
| | | }else if(poHistory.openDt.after(DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dataCd85Vo.startDt))){ |
| | | //匹配失败(对于after:等于或晚于都返回true) |
| | | //本地最新数据中的开阀时间晚于当前关阀上报中的开阀时间,说明是补报 |
| | | this.dealSupplyReport() ; |
| | | }else{ |
| | | //匹配失败 |
| | | //本地最新数据中的开阀时间早于当前关阀上报中的开阀时间,说明是新的一次关阀报,而且对应关阀报的上一次开阀报未收到 |
| | | //当前关阀不是原记录中开阀的对应关阀,说明是新的一次关阀报,而且对应关阀报的上一次开阀报未收到 |
| | | this.newHistoryDataDeal(sv, clientVo, controller, rtuAddr, dV202404, dataCd85Vo, poLast, true); |
| | | } |
| | | }else{ |
| | |
| | | } |
| | | } |
| | | }else if(poLast.opType != null){ |
| | | //原记录存在关阀数据,也存在开阀数据,首先进行开关阀时间对比 |
| | | if(poLast.closeDt != null && poLast.closeDt.equals(DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dataCd85Vo.endDt))){ |
| | | //原记录存在关阀数据,也存在开阀数据,首先进行对比 |
| | | if(poLast.clOrderNo != null && poLast.clOrderNo.equals(dataCd85Vo.orderNo)){ |
| | | //重复上报了,不进行处理 |
| | | }else if(poLast.closeDt != null && poLast.closeDt.after(DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dataCd85Vo.endDt))){ |
| | | //补报的许久之前的数据(对于after:等于或晚于都返回true) |
| | | this.dealSupplyReport() ; |
| | | }else { |
| | | //是新的上报关阀数据 |
| | | //进行历史数据匹配 |
| | |
| | | if(poLast.lastHistoryId != null) { |
| | | poHistory = sv.getRmOpenCloseValveHistory(poLast.lastHistoryId); |
| | | if (poHistory != null) { |
| | | if(poHistory.openDt.equals(DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dataCd85Vo.startDt))){ |
| | | //匹配上了 |
| | | this.updateCloseValve(clientVo, controller, rtuAddr, poLast, poHistory, dV202404, dataCd85Vo, false) ; |
| | | sv.updateRmOpenCloseValveHistory(poHistory); |
| | | if(poHistory.clOrderNo.equals(dataCd85Vo.orderNo)){ |
| | | //重复上报了,不进行处理 |
| | | }else{ |
| | | //上个关阀报未上报 |
| | | this.updateCloseValve(clientVo, controller, rtuAddr, poLast, null, dV202404, dataCd85Vo, true) ; |
| | | this.newHistoryDataDeal(sv, clientVo, controller, rtuAddr, dV202404, dataCd85Vo, poLast, null); |
| | | if(poLast.closeDt != null && poLast.closeDt.equals(DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dataCd85Vo.endDt))){ |
| | | //重复上报了,不进行处理 |
| | | }else if(poLast.closeDt != null && poLast.closeDt.after(DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dataCd85Vo.endDt))){ |
| | | //补报的许久之前的数据(对于after:等于或晚于都返回true) |
| | | this.dealSupplyReport() ; |
| | | }else { |
| | | //上个开阀报未上报 |
| | | this.updateCloseValve(clientVo, controller, rtuAddr, poLast, null, dV202404, dataCd85Vo, true) ; |
| | | this.newHistoryDataDeal(sv, clientVo, controller, rtuAddr, dV202404, dataCd85Vo, poLast, null); |
| | | } |
| | | } |
| | | }else{ |
| | | //这种情况不存在,但为安全也进行处理,也认为上个关阀报未上报 |