New file |
| | |
| | | package com.dy.pipIrrStatistics.largeScreen; |
| | | |
| | | import com.alibaba.fastjson2.JSON; |
| | | import com.alibaba.fastjson2.JSONObject; |
| | | import com.dy.common.mw.protocol.Command; |
| | | import com.dy.common.mw.protocol.CommandBackParam; |
| | | import com.dy.common.util.DateTime; |
| | | import com.dy.common.util.IDLongGenerator; |
| | | import com.dy.common.webUtil.BaseResponse; |
| | | import com.dy.pipIrrGlobal.daoLargeScreen.Ls4StatisticsMapper; |
| | | import com.dy.pipIrrGlobal.rtuMw.CodeLocal; |
| | | import com.dy.pipIrrGlobal.rtuMw.Web2RtuMw; |
| | | import com.dy.pipIrrGlobal.voLargeScreen.VoBaseInfo; |
| | | import com.dy.pipIrrGlobal.voLargeScreen.VoCurrentInfo; |
| | | import com.dy.pipIrrGlobal.voLargeScreen.VoMonitorInfo; |
| | | import com.dy.pipIrrGlobal.voSpecial.VoTopXClient; |
| | | import com.dy.pipIrrGlobal.voSpecial.VoTopXIntake; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.core.env.Environment; |
| | | import org.springframework.stereotype.Service; |
| | | import org.springframework.web.client.RestTemplate; |
| | | |
| | | import java.util.Date; |
| | | import java.util.List; |
| | | |
| | | /** |
| | | * @Author: liurunyu |
| | | * @Date: 2025/2/6 10:33 |
| | | * @Description |
| | | */ |
| | | @Slf4j |
| | | @Service |
| | | public class Ls4StatisticsSv extends Web2RtuMw { |
| | | private Environment env; |
| | | private RestTemplate restTemplate; |
| | | private Ls4StatisticsMapper dao ; |
| | | |
| | | @Autowired |
| | | private void setEnvironment(Environment env){ |
| | | this.env = env; |
| | | } |
| | | @Autowired |
| | | private void setRestTemplate(RestTemplate restTemplate){ |
| | | this.restTemplate = restTemplate; |
| | | } |
| | | @Autowired |
| | | private void setDao(Ls4StatisticsMapper dao){ |
| | | this.dao = dao; |
| | | } |
| | | |
| | | /** |
| | | * 基本信息统计 |
| | | * @return |
| | | */ |
| | | public VoBaseInfo baseInfo(){ |
| | | VoBaseInfo vo = new VoBaseInfo() ; |
| | | vo.totalCountOfTown = this.dao.totalCountOfDistrict(3) ; |
| | | vo.totalCountOfVillage = this.dao.totalCountOfDistrict(4) ; |
| | | vo.totalCountOfBlock = this.dao.totalCountOfBlock() ; |
| | | vo.totalCountOfDivide = this.dao.totalCountOfDivide() ; |
| | | vo.totalCountOfIntake = this.dao.totalCountOfIntake() ; |
| | | vo.totalCountOfIntakeWithController = this.dao.totalCountOfIntakeWithController() ; |
| | | vo.totalCountOfIntakeWithoutController = this.dao.totalCountOfIntakeWithoutController() ; |
| | | vo.totalCountOfController = this.dao.totalCountOfController() ; |
| | | vo.totalCountOfControllerTramp = this.dao.totalCountOfControllerTramp() ; |
| | | return vo ; |
| | | } |
| | | |
| | | /** |
| | | * 当前信息统计 |
| | | * @return |
| | | */ |
| | | public VoCurrentInfo currentInfo() throws Exception{ |
| | | Integer totalCountOfIntake = this.dao.totalCountOfIntake() ; |
| | | Date dtAtXHourBefore = DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(DateTime.lastXHour_yyyy_MM_dd_HH_mm_ss(24)) ;//X个小时前 |
| | | VoCurrentInfo vo = new VoCurrentInfo() ; |
| | | Integer[] result = this.queryMwOnAndOffLine() ; |
| | | vo.cTotalCountOfOnLine = result[0] ; |
| | | vo.cTotalCountOfOffLine = totalCountOfIntake - vo.cTotalCountOfOnLine; |
| | | vo.cTotalCountOfOffLine = vo.cTotalCountOfOffLine < 0 ? 0 : vo.cTotalCountOfOffLine ; |
| | | |
| | | vo.cTotalCountOfOpenValve = this.dao.totalCountOfOpenValve(dtAtXHourBefore) ; |
| | | vo.cTotalCountOfCloseValve = this.dao.totalCountOfCloseValve(dtAtXHourBefore) ; |
| | | vo.cTotalCountOfUnknownValve = totalCountOfIntake - vo.cTotalCountOfOpenValve - vo.cTotalCountOfCloseValve; |
| | | vo.cTotalCountOfUnknownValve = vo.cTotalCountOfUnknownValve < 0 ? 0 : vo.cTotalCountOfUnknownValve ; |
| | | |
| | | vo.cTotalCountOfAlarm = this.dao.totalCountOfAlarm(dtAtXHourBefore) ; |
| | | vo.cTotalCountOfNoAlarm = this.dao.totalCountOfNoAlarm(dtAtXHourBefore) ; |
| | | vo.cTotalCountOfUnknownAlarm = totalCountOfIntake - vo.cTotalCountOfAlarm - vo.cTotalCountOfNoAlarm; |
| | | vo.cTotalCountOfUnknownAlarm = vo.cTotalCountOfUnknownAlarm < 0 ? 0 : vo.cTotalCountOfUnknownAlarm ; |
| | | return vo ; |
| | | } |
| | | |
| | | /** |
| | | * 监测信息统计 |
| | | * @return |
| | | */ |
| | | public VoMonitorInfo monitorInfo(Date fromDt){ |
| | | VoMonitorInfo vo = new VoMonitorInfo() ; |
| | | vo.mTotalCountOfReport = this.dao.mTotalCountOfReport(fromDt) ; |
| | | vo.mTotalCountOfNoReport = this.dao.mTotalCountOfNoReport(fromDt) ; |
| | | vo.mTotalCountOfNeverReport = this.dao.mTotalCountOfNeverReport() ; |
| | | |
| | | vo.mTotalCountOfOpenValve = this.dao.mTotalCountOfOpenValve(fromDt) ; |
| | | vo.mTotalCountOfCloseValve = this.dao.mTotalCountOfCloseValve(fromDt) ; |
| | | vo.mTotalCountOfNeverOpenValve = this.dao.mTotalCountOfNeverOpenValve() ; |
| | | |
| | | vo.mTotalCountOfAlarm = this.dao.mTotalCountOfAlarm(fromDt) ; |
| | | vo.mTotalCountOfNoAlarm = this.dao.mTotalCountOfNoAlarm(fromDt) ; |
| | | vo.mTotalCountOfNeverAlarm = this.dao.mTotalCountOfNeverAlarm() ; |
| | | |
| | | return vo ; |
| | | } |
| | | |
| | | /** |
| | | * 查询取水口在线和离线统计 |
| | | * @return |
| | | */ |
| | | private Integer[] queryMwOnAndOffLine() { |
| | | Integer[] result = new Integer[]{0,0} ; |
| | | //向通信中间件发关命令,查询RTU在线统计情况 |
| | | Command com = this.createInnerCommand(CodeLocal.onLineStatistics); |
| | | String rqUrl = this.get2MwRequestUrl(this.env, ContextComSend) ; |
| | | BaseResponse res = this.sendPostRequest2Mw(restTemplate, rqUrl, com) ; |
| | | if(res != null){ |
| | | if(res.isSuccess()){ |
| | | Command reCom = JSON.parseObject(res.getContent() == null ? null : JSON.toJSONString(res.getContent()), Command.class) ; |
| | | CommandBackParam bakParam = JSON.parseObject((reCom== null || reCom.param == null) ? null : JSON.toJSONString(reCom.param), CommandBackParam.class) ; |
| | | if(bakParam != null){ |
| | | if(bakParam.getSuccess().booleanValue() && reCom.getAttachment() != null){ |
| | | //通信中间件成功返回命令结果 |
| | | JSONObject comRes = (JSONObject) JSON.toJSON(reCom.getAttachment()); |
| | | result[0] = comRes.getInteger("onLineNum") ; |
| | | result[1] = comRes.getInteger("offLineNum") ; |
| | | } |
| | | }else{ |
| | | log.error("通信中间件返回内部命令结果中不包含CommandBackParam类型参数"); |
| | | } |
| | | }else{ |
| | | log.error("通信中间件返回内部命令执行失败" + (res.getMsg() == null? "" : ("," + res.getMsg()))) ; |
| | | } |
| | | }else{ |
| | | log.error("通信中间件返回内部命令结果为null"); |
| | | } |
| | | return result ; |
| | | } |
| | | |
| | | |
| | | |
| | | /** |
| | | * 昨日农户用水前5名统计 |
| | | * @return 数据集合 |
| | | */ |
| | | public List<VoTopXClient> top5ClientYesterday() { |
| | | int[] yesterday = DateTime.yyyy_MM_dd_2_ymdGroup(DateTime.lastXDay_yyyy_MM_dd(1)) ; |
| | | Long idStart = IDLongGenerator.generateOneDayStartId(yesterday[0], yesterday[1], yesterday[2]) ; |
| | | Long idEnd = IDLongGenerator.generateOneDayEndId(yesterday[0], yesterday[1], yesterday[2]) ; |
| | | return this.dao.topXClientAtCertainDay(idStart, idEnd, 5) ; |
| | | } |
| | | |
| | | /** |
| | | * 昨日取水口用水前5名统计 |
| | | * @return 数据集合 |
| | | */ |
| | | public List<VoTopXIntake> top5IntakeYesterday() { |
| | | int[] yesterday = DateTime.yyyy_MM_dd_2_ymdGroup(DateTime.lastXDay_yyyy_MM_dd(1)) ; |
| | | Long idStart = IDLongGenerator.generateOneDayStartId(yesterday[0], yesterday[1], yesterday[2]) ; |
| | | Long idEnd = IDLongGenerator.generateOneDayEndId(yesterday[0], yesterday[1], yesterday[2]) ; |
| | | return this.dao.topXIntakeAtCertainDay(idStart, idEnd, 5) ; |
| | | } |
| | | |
| | | } |