Merge branch 'master' of http://8.140.179.55:20000/r/pipIrr-SV
Conflicts:
pipIrr-platform/pipIrr-web/pipIrr-web-statistics/src/main/java/com/dy/pipIrrStatistics/client/ClientCtrl.java
pipIrr-platform/pipIrr-web/pipIrr-web-statistics/src/main/java/com/dy/pipIrrStatistics/client/ClientSv.java
| | |
| | | import lombok.Data; |
| | | |
| | | /** |
| | | * 遥测站自报实时数据 |
| | | * 遥测站自报(整点)实时数据 |
| | | */ |
| | | @Data |
| | | public class DataCdC0Vo { |
| | |
| | | |
| | | @Data |
| | | public class DataStateVo { |
| | | public static final byte ValveOpenState = 0 ; |
| | | public static final byte ValveCloseState = 1 ; |
| | | |
| | | public Byte icCard;// IC卡功能 |
| | | public Byte valveState;//阀门状态 |
| | | public Byte powerType ;//电源状态(0:220V供电,1:畜电池供电) |
| | |
| | | import com.baomidou.mybatisplus.core.mapper.BaseMapper; |
| | | import com.dy.pipIrrGlobal.pojoSe.SeCardOperate; |
| | | import com.dy.pipIrrGlobal.voSe.*; |
| | | import com.dy.pipIrrGlobal.voSt.VoClient; |
| | | import com.dy.pipIrrGlobal.voSt.VoClientOpenCardCount; |
| | | import com.dy.pipIrrGlobal.voSt.VoClientRechargeTotal; |
| | | import org.apache.ibatis.annotations.Mapper; |
| | | |
| | | import java.util.List; |
| | |
| | | * @return |
| | | */ |
| | | Long getRechargeCountIcCardsCount(Map<String, Object> params); |
| | | |
| | | /** |
| | | * 指定时间段内开物理卡农户数量 |
| | | * @param params |
| | | * @return |
| | | */ |
| | | Long getOpenIcCardClientsCount(Map<String, Object> params); |
| | | |
| | | /** |
| | | * 指定时间段内开物理卡农户 |
| | | * @param params |
| | | * @return |
| | | */ |
| | | List<VoClientOpenCardCount> getOpenIcCardClients(Map<String, Object> params); |
| | | |
| | | /** |
| | | * 指定时间段内每个农户充值合计 农户数量 |
| | | * @param params |
| | | * @return |
| | | */ |
| | | Long getRechargeTotalClientsCount(Map<String, Object> params); |
| | | |
| | | /** |
| | | * 指定时间段内每个农户充值合计 |
| | | * @param params |
| | | * @return |
| | | */ |
| | | List<VoClientRechargeTotal> getRechargeTotalClients(Map<String, Object> params); |
| | | |
| | | /** |
| | | * 指定时间段内物理卡充值金额超过指定值的农户数量 |
| | | * @param params |
| | | * @return |
| | | */ |
| | | Long getRechargeTotalGtValueClientsCount(Map<String, Object> params); |
| | | |
| | | /** |
| | | * 指定时间段内物理卡充值金额超过指定值的农户 |
| | | * @param params |
| | | * @return |
| | | */ |
| | | List<VoClientRechargeTotal> getRechargeTotalGtValueClients(Map<String, Object> params); |
| | | } |
| | |
| | | @Schema(description = "统计日期(yyyy-mm-dd)", requiredMode = Schema.RequiredMode.NOT_REQUIRED) |
| | | @DateTimeFormat(pattern = "yyyy-MM-dd") |
| | | @JsonFormat(pattern = "yyyy-MM-dd") |
| | | private java.sql.Date dt; |
| | | private java.util.Date dt; |
| | | |
| | | @Schema(description = "控制器最后上报数据日期时间(yyyy-mm-dd hh:mm:ss)", requiredMode = Schema.RequiredMode.NOT_REQUIRED) |
| | | @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") |
New file |
| | |
| | | package com.dy.pipIrrGlobal.voSt; |
| | | |
| | | import lombok.Data; |
| | | |
| | | /** |
| | | * @author :WuZeYu |
| | | * @Date :2024/8/9 10:18 |
| | | * @LastEditTime :2024/8/9 10:18 |
| | | * @Description |
| | | */ |
| | | @Data |
| | | public class VoClientOpenCardCount extends VoClient{ |
| | | private static final long serialVersionUID = 202408091019001L; |
| | | /** |
| | | * 开卡次数 |
| | | */ |
| | | private Long openCardCount; |
| | | } |
New file |
| | |
| | | package com.dy.pipIrrGlobal.voSt; |
| | | |
| | | import lombok.Data; |
| | | |
| | | /** |
| | | * @author :WuZeYu |
| | | * @Date :2024/8/9 10:58 |
| | | * @LastEditTime :2024/8/9 10:58 |
| | | * @Description |
| | | */ |
| | | @Data |
| | | public class VoClientRechargeTotal extends VoClient{ |
| | | |
| | | /** |
| | | *充值总量 |
| | | */ |
| | | private Double rechargeTotal; |
| | | } |
| | |
| | | |
| | | pipIrr: |
| | | global: |
| | | dev: false #是否开发阶段,true或false |
| | | dev: true #是否开发阶段,true或false |
| | | dsName: ym #开发阶段,设置临时的数据库名称 |
| | | mw: |
| | | webPort: 8070 |
| | |
| | | WHERE |
| | | operate_dt BETWEEN #{timeStart} AND #{timeStop} AND operate_type = 2 |
| | | </select> |
| | | <!--指定时间段内开物理卡农户数量--> |
| | | <select id="getOpenIcCardClientsCount" resultType="java.lang.Long"> |
| | | select |
| | | count(*) |
| | | from |
| | | ( |
| | | SELECT |
| | | sco.client_id AS clientId, |
| | | sc.`name` AS clientName, |
| | | sc.clientNum AS clientNum, |
| | | sc.address AS address, |
| | | sc.phone AS phone, |
| | | sc.idCard AS idCard, |
| | | COUNT(sc.id) AS openCardCount |
| | | FROM |
| | | `se_card_operate` sco |
| | | INNER JOIN se_client sc ON sc.id = sco.client_id |
| | | WHERE |
| | | sco.operate_dt BETWEEN #{timeStart} AND #{timeStop} AND sco.operate_type = 1 AND sc.deleted = 0 AND sc.disabled = 0 |
| | | GROUP BY sc.id) c |
| | | </select> |
| | | <!--指定时间段内开物理卡农户--> |
| | | <select id="getOpenIcCardClients" resultType="com.dy.pipIrrGlobal.voSt.VoClientOpenCardCount"> |
| | | SELECT |
| | | sco.client_id AS clientId, |
| | | sc.`name` AS clientName, |
| | | sc.clientNum AS clientNum, |
| | | sc.address AS address, |
| | | sc.phone AS phone, |
| | | sc.idCard AS idCard, |
| | | COUNT(sc.id) AS openCardCount |
| | | FROM |
| | | `se_card_operate` sco |
| | | INNER JOIN se_client sc ON sc.id = sco.client_id |
| | | WHERE |
| | | sco.operate_dt BETWEEN #{timeStart} AND #{timeStop} AND sco.operate_type = 1 AND sc.deleted = 0 AND sc.disabled = 0 |
| | | GROUP BY sc.id |
| | | ORDER BY sc.id DESC |
| | | <trim prefix="limit " > |
| | | <if test="start != null and count != null"> |
| | | #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER} |
| | | </if> |
| | | </trim> |
| | | </select> |
| | | <!--指定时间段内每个农户充值合计 农户数量--> |
| | | <select id="getRechargeTotalClientsCount" resultType="java.lang.Long"> |
| | | select |
| | | count(*) |
| | | from |
| | | ( |
| | | SELECT |
| | | sco.client_id AS clientId, |
| | | sc.`name` AS clientName, |
| | | sc.clientNum AS clientNum, |
| | | sc.address AS address, |
| | | sc.phone AS phone, |
| | | sc.idCard AS idCard, |
| | | IFNULL(SUM(sco.trade_amount),0) AS rechargeTotal |
| | | FROM |
| | | `se_card_operate` sco |
| | | INNER JOIN se_client sc ON sc.id = sco.client_id |
| | | WHERE |
| | | sco.operate_dt BETWEEN #{timeStart} AND #{timeStop} AND sco.operate_type = 2 AND sc.deleted = 0 AND sc.disabled = 0 |
| | | GROUP BY sc.id) c |
| | | </select> |
| | | <!--指定时间段内每个农户充值合计--> |
| | | <select id="getRechargeTotalClients" resultType="com.dy.pipIrrGlobal.voSt.VoClientRechargeTotal"> |
| | | SELECT |
| | | sco.client_id AS clientId, |
| | | sc.`name` AS clientName, |
| | | sc.clientNum AS clientNum, |
| | | sc.address AS address, |
| | | sc.phone AS phone, |
| | | sc.idCard AS idCard, |
| | | IFNULL(SUM(sco.trade_amount),0) AS rechargeTotal |
| | | FROM |
| | | `se_card_operate` sco |
| | | INNER JOIN se_client sc ON sc.id = sco.client_id |
| | | WHERE |
| | | sco.operate_dt BETWEEN #{timeStart} AND #{timeStop} AND sco.operate_type = 2 AND sc.deleted = 0 AND sc.disabled = 0 |
| | | GROUP BY sc.id |
| | | ORDER BY sc.id DESC |
| | | <trim prefix="limit " > |
| | | <if test="start != null and count != null"> |
| | | #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER} |
| | | </if> |
| | | </trim> |
| | | </select> |
| | | <!--指定时间段内物理卡充值金额超过指定值的农户数量--> |
| | | <select id="getRechargeTotalGtValueClientsCount" resultType="java.lang.Long"> |
| | | select |
| | | count(*) |
| | | from |
| | | ( |
| | | SELECT |
| | | sco.client_id AS clientId, |
| | | sc.`name` AS clientName, |
| | | sc.clientNum AS clientNum, |
| | | sc.address AS address, |
| | | sc.phone AS phone, |
| | | sc.idCard AS idCard, |
| | | IFNULL(SUM(sco.trade_amount),0) AS rechargeTotal |
| | | FROM |
| | | `se_card_operate` sco |
| | | INNER JOIN se_client sc ON sc.id = sco.client_id |
| | | WHERE |
| | | sco.operate_dt BETWEEN #{timeStart} AND #{timeStop} AND sco.operate_type = 2 AND sc.deleted = 0 AND sc.disabled = 0 |
| | | GROUP BY sc.id |
| | | HAVING IFNULL(SUM(sco.trade_amount),0) > #{value}) c |
| | | </select> |
| | | <!--指定时间段内物理卡充值金额超过指定值的农户--> |
| | | <select id="getRechargeTotalGtValueClients" resultType="com.dy.pipIrrGlobal.voSt.VoClientRechargeTotal"> |
| | | SELECT |
| | | sco.client_id AS clientId, |
| | | sc.`name` AS clientName, |
| | | sc.clientNum AS clientNum, |
| | | sc.address AS address, |
| | | sc.phone AS phone, |
| | | sc.idCard AS idCard, |
| | | IFNULL(SUM(sco.trade_amount),0) AS rechargeTotal |
| | | FROM |
| | | `se_card_operate` sco |
| | | INNER JOIN se_client sc ON sc.id = sco.client_id |
| | | WHERE |
| | | sco.operate_dt BETWEEN #{timeStart} AND #{timeStop} AND sco.operate_type = 2 AND sc.deleted = 0 AND sc.disabled = 0 |
| | | GROUP BY sc.id |
| | | HAVING IFNULL(SUM(sco.trade_amount),0) > #{value} |
| | | ORDER BY sc.id DESC |
| | | <trim prefix="limit " > |
| | | <if test="start != null and count != null"> |
| | | #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER} |
| | | </if> |
| | | </trim> |
| | | </select> |
| | | </mapper> |
| | |
| | | PrController controller = (PrController) objs[1]; |
| | | this.saveOrUpdateLast(sv, controller, d.getRtuAddr(), dataCd81Vo.rtuDt, dV1_0_1, dataCd81Vo.alarmVo, dataCd81Vo.stateVo); |
| | | this.saveHistory(sv, controller, d.getRtuAddr(), dataCd81Vo.rtuDt, dV1_0_1, dataCd81Vo.alarmVo, dataCd81Vo.stateVo); |
| | | this.updateVirCardNoUseState(sv, controller, dataCd81Vo.stateVo) ; |
| | | if(dataCd81Vo.stateVo != null && dataCd81Vo.stateVo.valveState != null && dataCd81Vo.stateVo.valveState.byteValue() == DataStateVo.ValveCloseState){ |
| | | if(controller != null && controller.getIntakeId() != null){ |
| | | this.taskResult = new Object[]{controller.getIntakeId(), DataStateVo.ValveCloseState} ; |
| | | } |
| | | } |
| | | } |
| | | } else if (cdObj instanceof DataCd84Vo) { |
| | | DataCd84Vo dataCd84Vo = (DataCd84Vo)cdObj ; |
| | |
| | | PrController controller = (PrController) objs[1]; |
| | | this.saveOrUpdateLast(sv, controller, d.getRtuAddr(), dataCd84Vo.rtuDt, dV1_0_1, dataCd84Vo.alarmVo, dataCd84Vo.stateVo); |
| | | this.saveHistory(sv, controller, d.getRtuAddr(), dataCd84Vo.rtuDt, dV1_0_1, dataCd84Vo.alarmVo, dataCd84Vo.stateVo); |
| | | this.updateVirCardNoUseState(sv, controller, dataCd84Vo.stateVo) ; |
| | | /** 阀开工作报,阀门状态一定是打开状态,所以不设置下面数据以备后续任务设置虚拟卡状态 |
| | | if(dataCd84Vo.stateVo != null && dataCd84Vo.stateVo.valveState != null && dataCd84Vo.stateVo.valveState.byteValue() == DataStateVo.ValveCloseState){ |
| | | if(controller != null && controller.getIntakeId() != null){ |
| | | this.taskResult = new Object[]{controller.getIntakeId(), DataStateVo.ValveCloseState} ; |
| | | } |
| | | }*/ |
| | | } |
| | | } else if (cdObj instanceof DataCdC0Vo) { |
| | | DataCdC0Vo dataCdC0Vo = (DataCdC0Vo)cdObj ; |
| | |
| | | PrController controller = (PrController) objs[1]; |
| | | this.saveOrUpdateLast(sv, controller, d.getRtuAddr(), dataCdC0Vo.rtuDt, dV1_0_1, dataCdC0Vo.alarmVo, dataCdC0Vo.stateVo); |
| | | this.saveHistory(sv, controller, d.getRtuAddr(), dataCdC0Vo.rtuDt, dV1_0_1, dataCdC0Vo.alarmVo, dataCdC0Vo.stateVo); |
| | | this.updateVirCardNoUseState(sv, controller, dataCdC0Vo.stateVo) ; |
| | | if(dataCdC0Vo.stateVo != null && dataCdC0Vo.stateVo.valveState != null && dataCdC0Vo.stateVo.valveState.byteValue() == DataStateVo.ValveCloseState){ |
| | | if(controller != null && controller.getIntakeId() != null){ |
| | | this.taskResult = new Object[]{controller.getIntakeId(), DataStateVo.ValveCloseState} ; |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } catch (Exception e) { |
| | |
| | | } |
| | | |
| | | |
| | | /** |
| | | * 虚拟卡在取水口上的占用状态改为非应用状态 |
| | | */ |
| | | private void updateVirCardNoUseState(DbSv sv, |
| | | PrController controller, |
| | | DataStateVo stateVo){ |
| | | if(stateVo != null){ |
| | | if(stateVo.valveState != null && stateVo.valveState.byteValue() == 0){ |
| | | //阀门关闭状态 |
| | | if(controller != null && controller.getIntakeId() != null){ |
| | | //虚拟卡在取水中的占用状态改为非应用状态 |
| | | sv.updateVirCardNoUseState(controller.getIntakeId()); |
| | | } |
| | | } |
| | | } |
| | | |
| | | } |
| | | |
| | | /** |
| | | * 向钉钉发送消息 |
| | |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * 处理补报,暂时无逻辑 |
| | | */ |
| | | private void dealSupplyReport(){ |
| | | |
| | | } |
| | | |
| | | /** |
| | |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * 处理补报,暂时无逻辑 |
| | | */ |
| | | private void dealSupplyReport(){ |
| | | |
| | | } |
| | | |
| | | /** |
New file |
| | |
| | | package com.dy.rtuMw.server.rtuData.p206V1_0_0; |
| | | |
| | | import com.dy.common.mw.protocol.p206V1_0_0.upVos.DataStateVo; |
| | | 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/8/9 9:49 |
| | | * @Description |
| | | */ |
| | | public class TkDealVirCardState extends TaskSurpport { |
| | | |
| | | private static final Logger log = LogManager.getLogger(TkDealVirCardState.class.getName()) ; |
| | | |
| | | //类ID,一定与Tree.xml配置文件中配置一致 |
| | | public static final String taskId = "TkDealVirCardState" ; |
| | | |
| | | /** |
| | | * 执行节点任务:虚拟卡在取水口上的占用状态改为非占用状态 |
| | | * @param data 需要处理的数据 |
| | | */ |
| | | @Override |
| | | public void execute(Object data) { |
| | | Object[] objs = this.getTaskResults(TkDealAlarmStatus.taskId); |
| | | if(objs != null && objs.length >= 2){ |
| | | Long intakeId = (Long)objs[0] ; |
| | | Byte valveState = (Byte)objs[1] ; |
| | | if(intakeId != null && valveState.byteValue() == DataStateVo.ValveCloseState){ |
| | | objs = this.getTaskResults(TkPreGenObjs.taskId); |
| | | DbSv sv = (DbSv) objs[0]; |
| | | //虚拟卡在取水口上的占用状态改为非占用状态 |
| | | sv.updateVirCardNoUseState(intakeId); |
| | | } |
| | | } |
| | | } |
| | | |
| | | } |
| | |
| | | <task id="TkDealControllerNoTramp" name="非流浪者RTU" enable="true" class="com.dy.rtuMw.server.rtuData.p206V1_0_0.TkDealControllerNoTramp"> |
| | | <!-- 识别非命令应答上行数据 --> |
| | | <task id="TkFindReport" name="识别非命令应答上行数据" enable="true" class="com.dy.rtuMw.server.rtuData.p206V1_0_0.TkFindReport"> |
| | | <task id="TkDealAlarmStatus" name="控制器报警与状态数据" enable="true" class="com.dy.rtuMw.server.rtuData.p206V1_0_0.TkDealAlarmStatus" /> |
| | | <task id="TkDealAlarmStatus" name="控制器报警与状态及向钉钉发送报警信息" enable="true" class="com.dy.rtuMw.server.rtuData.p206V1_0_0.TkDealAlarmStatus"> |
| | | <task id="TkDealVirCardState" name="虚拟卡占用状态恢复" enable="true" class="com.dy.rtuMw.server.rtuData.p206V1_0_0.TkDealVirCardState" /> |
| | | </task> |
| | | <task id="TkDealOnHourReport" name="控制器自报数据(整点报)(功能码C0)" enable="true" class="com.dy.rtuMw.server.rtuData.p206V1_0_0.TkDealOnHourReport" /> |
| | | <task id="TkDealWorkReport" name="控制器阀开工作上报(功能码84)" enable="true" class="com.dy.rtuMw.server.rtuData.p206V1_0_0.TkDealWorkReport" /> |
| | | <task id="TkDealOpenValveReport" name="控制器开阀上报(功能码83)" enable="true" class="com.dy.rtuMw.server.rtuData.p206V1_0_0.TkDealOpenValveReport" /> |
| | |
| | | </task> |
| | | <!-- 识别命令响应数据 --> |
| | | <task id="TkFindComResponse" name="识别响应命令数据" enable="true" class="com.dy.rtuMw.server.rtuData.p206V1_0_0.TkFindComResponse"> |
| | | <task id="TkRtuDealCommandResponse" name="RTU响应命令数据" enable="true" class="com.dy.rtuMw.server.rtuData.p206V1_0_0.TkRtuDealCommandResponse" > |
| | | </task> |
| | | <task id="TkRtuDealCommandResponse" name="RTU响应命令数据" enable="true" class="com.dy.rtuMw.server.rtuData.p206V1_0_0.TkRtuDealCommandResponse" /> |
| | | </task> |
| | | </task> |
| | | </task> |
| | |
| | | import com.dy.common.webUtil.BaseResponseUtils; |
| | | import com.dy.common.webUtil.QueryResultVo; |
| | | import com.dy.pipIrrGlobal.voSt.VoClient; |
| | | import com.dy.pipIrrGlobal.voSt.VoClientOpenCardCount; |
| | | import com.dy.pipIrrGlobal.voSt.VoClientRechargeTotal; |
| | | import com.dy.pipIrrGlobal.voSt.VoICCard; |
| | | import com.dy.pipIrrStatistics.card.IcCardqo.CommonQO; |
| | | import com.dy.pipIrrStatistics.client.qo.*; |
| | | import com.dy.pipIrrGlobal.voSt.VoDayClient; |
| | | import com.dy.pipIrrGlobal.voSt.VoMonthClient; |
| | | import com.dy.pipIrrStatistics.client.qo.AmountSpentQO; |
| | |
| | | return BaseResponseUtils.buildException(e.getMessage()) ; |
| | | } |
| | | } |
| | | |
| | | |
| | | /** |
| | | * 指定时间段内开物理卡农户 |
| | | * |
| | | * @param qo |
| | | * @return |
| | | */ |
| | | @GetMapping(path = "/getOpenIcCardClients") |
| | | @SsoAop() |
| | | public BaseResponse<QueryResultVo<List<VoClientOpenCardCount>>> getOpenIcCardClients(CommonQO qo) { |
| | | try { |
| | | QueryResultVo<List<VoClientOpenCardCount>> res = clientSv.getOpenIcCardClients(qo); |
| | | return BaseResponseUtils.buildSuccess(res); |
| | | }catch (Exception e){ |
| | | log.error("获取记录异常", e); |
| | | return BaseResponseUtils.buildException(e.getMessage()); |
| | | } |
| | | } |
| | | |
| | | |
| | | |
| | | /** |
| | | * 指定时间段内每个农户充值合计(物理卡) |
| | | * |
| | | * @param qo |
| | | * @return |
| | | */ |
| | | @GetMapping(path = "/getRechargeTotalClients") |
| | | @SsoAop() |
| | | public BaseResponse<QueryResultVo<List<VoClientRechargeTotal>>> getRechargeTotalClients(CommonQO qo) { |
| | | try { |
| | | QueryResultVo<List<VoClientRechargeTotal>> res = clientSv.getRechargeTotalClients(qo); |
| | | return BaseResponseUtils.buildSuccess(res); |
| | | }catch (Exception e){ |
| | | log.error("获取记录异常", e); |
| | | return BaseResponseUtils.buildException(e.getMessage()); |
| | | } |
| | | } |
| | | |
| | | |
| | | /** |
| | | * 指定时间段内物理卡充值金额超过指定值的农户 |
| | | * |
| | | * @param qo |
| | | * @return |
| | | */ |
| | | @GetMapping(path = "/getRechargeTotalGtValueClients") |
| | | @SsoAop() |
| | | public BaseResponse<QueryResultVo<List<VoClientRechargeTotal>>> getRechargeTotalGtValueClients(RechargeTotalGtValueQo qo) { |
| | | try { |
| | | QueryResultVo<List<VoClientRechargeTotal>> res = clientSv.getRechargeTotalGtValueClients(qo); |
| | | return BaseResponseUtils.buildSuccess(res); |
| | | }catch (Exception e){ |
| | | log.error("获取记录异常", e); |
| | | return BaseResponseUtils.buildException(e.getMessage()); |
| | | } |
| | | } |
| | | |
| | | } |
| | |
| | | import com.dy.common.webUtil.QueryResultVo; |
| | | import com.dy.pipIrrGlobal.daoRm.RmClientAmountDayLastMapper; |
| | | import com.dy.pipIrrGlobal.daoRm.RmOpenCloseValveHistoryMapper; |
| | | import com.dy.pipIrrGlobal.daoSe.SeCardOperateMapper; |
| | | import com.dy.pipIrrGlobal.voSt.VoClient; |
| | | import com.dy.pipIrrGlobal.voSt.VoDayClient; |
| | | import com.dy.pipIrrGlobal.voSt.VoMonthClient; |
| | |
| | | import com.dy.pipIrrStatistics.client.qo.WaterConsumptionQO; |
| | | import com.dy.pipIrrStatistics.client.qo.WaterDurationQO; |
| | | import com.dy.pipIrrStatistics.intake.qo.ClientAmountQO; |
| | | import com.dy.pipIrrGlobal.voSt.VoClientOpenCardCount; |
| | | import com.dy.pipIrrGlobal.voSt.VoClientRechargeTotal; |
| | | import com.dy.pipIrrGlobal.voSt.VoICCard; |
| | | import com.dy.pipIrrStatistics.card.IcCardqo.CommonQO; |
| | | import com.dy.pipIrrStatistics.client.qo.*; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | import org.apache.dubbo.common.utils.PojoUtils; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.stereotype.Service; |
| | | |
| | | import java.text.ParseException; |
| | | import java.time.LocalDate; |
| | | import java.util.Calendar; |
| | | import java.util.List; |
| | | import java.util.Map; |
| | | import java.util.Optional; |
| | |
| | | public class ClientSv { |
| | | @Autowired |
| | | private RmOpenCloseValveHistoryMapper rmOpenCloseValveHistoryMapper; |
| | | @Autowired |
| | | private SeCardOperateMapper seCardOperateMapper; |
| | | |
| | | @Autowired |
| | | private RmClientAmountDayLastMapper rmClientAmountDayLastMapper; |
| | |
| | | } |
| | | |
| | | /** |
| | | * 指定时间段内开物理卡农户 |
| | | * @param qo |
| | | * @return |
| | | */ |
| | | public QueryResultVo<List<VoClientOpenCardCount>> getOpenIcCardClients(CommonQO qo) { |
| | | |
| | | String timeStart = qo.getTimeStart(); |
| | | String timeStop = qo.getTimeStop(); |
| | | |
| | | if (timeStart != null && timeStart != ""){ |
| | | timeStart = timeStart + " 00:00:00"; |
| | | }else { |
| | | timeStart = LocalDate.now() + " 00:00:00"; |
| | | } |
| | | if (timeStop != null && timeStop != ""){ |
| | | timeStop = timeStop + " 23:59:59"; |
| | | }else { |
| | | timeStop = LocalDateTime.now().toString(); |
| | | } |
| | | qo.setTimeStart(timeStart); |
| | | qo.setTimeStop(timeStop); |
| | | |
| | | Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(qo); |
| | | Long itemTotal = seCardOperateMapper.getOpenIcCardClientsCount(params); |
| | | |
| | | QueryResultVo<List<VoClientOpenCardCount>> rsVo = new QueryResultVo<>() ; |
| | | rsVo.pageSize = qo.pageSize ; |
| | | rsVo.pageCurr = qo.pageCurr ; |
| | | |
| | | rsVo.calculateAndSet(itemTotal, params); |
| | | rsVo.obj = seCardOperateMapper.getOpenIcCardClients(params); |
| | | return rsVo ; |
| | | } |
| | | |
| | | /** |
| | | * 指定时间段内每个农户充值合计(物理卡) |
| | | * @param qo |
| | | * @return |
| | | */ |
| | | public QueryResultVo<List<VoClientRechargeTotal>> getRechargeTotalClients(CommonQO qo) { |
| | | |
| | | String timeStart = qo.getTimeStart(); |
| | | String timeStop = qo.getTimeStop(); |
| | | |
| | | if (timeStart != null && timeStart != ""){ |
| | | timeStart = timeStart + " 00:00:00"; |
| | | }else { |
| | | timeStart = LocalDate.now() + " 00:00:00"; |
| | | } |
| | | if (timeStop != null && timeStop != ""){ |
| | | timeStop = timeStop + " 23:59:59"; |
| | | }else { |
| | | timeStop = LocalDateTime.now().toString(); |
| | | } |
| | | qo.setTimeStart(timeStart); |
| | | qo.setTimeStop(timeStop); |
| | | |
| | | Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(qo); |
| | | Long itemTotal = seCardOperateMapper.getRechargeTotalClientsCount(params); |
| | | |
| | | QueryResultVo<List<VoClientRechargeTotal>> rsVo = new QueryResultVo<>() ; |
| | | rsVo.pageSize = qo.pageSize ; |
| | | rsVo.pageCurr = qo.pageCurr ; |
| | | |
| | | rsVo.calculateAndSet(itemTotal, params); |
| | | rsVo.obj = seCardOperateMapper.getRechargeTotalClients(params); |
| | | return rsVo ; |
| | | } |
| | | |
| | | /** |
| | | * 指定时间段内物理卡充值金额超过指定值的农户 |
| | | * @param qo |
| | | * @return |
| | | */ |
| | | public QueryResultVo<List<VoClientRechargeTotal>> getRechargeTotalGtValueClients(RechargeTotalGtValueQo qo) { |
| | | |
| | | String timeStart = qo.getTimeStart(); |
| | | String timeStop = qo.getTimeStop(); |
| | | |
| | | if (timeStart != null && timeStart != ""){ |
| | | timeStart = timeStart + " 00:00:00"; |
| | | }else { |
| | | timeStart = LocalDate.now() + " 00:00:00"; |
| | | } |
| | | if (timeStop != null && timeStop != ""){ |
| | | timeStop = timeStop + " 23:59:59"; |
| | | }else { |
| | | timeStop = LocalDateTime.now().toString(); |
| | | } |
| | | qo.setTimeStart(timeStart); |
| | | qo.setTimeStop(timeStop); |
| | | |
| | | if (qo.getValue() == null || qo.getValue() < 0){ |
| | | qo.setValue(0.0); |
| | | } |
| | | |
| | | Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(qo); |
| | | Long itemTotal = seCardOperateMapper.getRechargeTotalGtValueClientsCount(params); |
| | | |
| | | QueryResultVo<List<VoClientRechargeTotal>> rsVo = new QueryResultVo<>() ; |
| | | rsVo.pageSize = qo.pageSize ; |
| | | rsVo.pageCurr = qo.pageCurr ; |
| | | |
| | | rsVo.calculateAndSet(itemTotal, params); |
| | | rsVo.obj = seCardOperateMapper.getRechargeTotalGtValueClients(params); |
| | | return rsVo ; |
| | | } |
| | | |
| | | /** |
| | | * 统计指定月份各农户各天用水量及消费金额 |
| | | * @param qo |
| | | * @return |
New file |
| | |
| | | package com.dy.pipIrrStatistics.client.qo; |
| | | |
| | | import com.alibaba.fastjson2.annotation.JSONField; |
| | | import com.alibaba.fastjson2.writer.ObjectWriterImplToString; |
| | | import com.dy.pipIrrStatistics.card.IcCardqo.CommonQO; |
| | | import lombok.Data; |
| | | |
| | | /** |
| | | * @author :WuZeYu |
| | | * @Date :2024/8/9 11:36 |
| | | * @LastEditTime :2024/8/9 11:36 |
| | | * @Description |
| | | */ |
| | | @Data |
| | | public class RechargeTotalGtValueQo extends CommonQO { |
| | | /** |
| | | * 金额值 |
| | | */ |
| | | @JSONField(serializeUsing= ObjectWriterImplToString.class) |
| | | private Double value; |
| | | } |