|  |  |  | 
|---|
|  |  |  | <result column="cl_this_amount" jdbcType="DOUBLE" property="clThisAmount"/> | 
|---|
|  |  |  | <result column="cl_this_money" jdbcType="DOUBLE" property="clThisMoney"/> | 
|---|
|  |  |  | <result column="cl_this_time" jdbcType="INTEGER" property="clThisTime"/> | 
|---|
|  |  |  | <result column="cl_price" jdbcType="DOUBLE" property="clPrice"/> | 
|---|
|  |  |  | <result column="cl_open_dt" jdbcType="TIMESTAMP" property="clOpenDt"/> | 
|---|
|  |  |  | <result column="close_dt" jdbcType="TIMESTAMP" property="closeDt"/> | 
|---|
|  |  |  | <result column="cl_order_no" jdbcType="VARCHAR" property="clOrderNo"/> | 
|---|
|  |  |  | 
|---|
|  |  |  | cl_this_amount, | 
|---|
|  |  |  | cl_this_money, | 
|---|
|  |  |  | cl_this_time, | 
|---|
|  |  |  | cl_price, | 
|---|
|  |  |  | cl_open_dt, | 
|---|
|  |  |  | close_dt, | 
|---|
|  |  |  | cl_order_no, | 
|---|
|  |  |  | 
|---|
|  |  |  | op_ele_total_amount, op_water_remain_user, cl_dt, | 
|---|
|  |  |  | cl_type, cl_total_amount, cl_ic_card_no, | 
|---|
|  |  |  | cl_ic_card_addr, cl_remain_money, cl_this_amount, | 
|---|
|  |  |  | cl_this_money, cl_this_time, cl_open_dt, | 
|---|
|  |  |  | cl_this_money, cl_this_time, cl_price, cl_open_dt, | 
|---|
|  |  |  | close_dt, cl_order_no, cl_ele_total_amount, | 
|---|
|  |  |  | cl_water_remain_user, cl_this_ele) | 
|---|
|  |  |  | values (#{id,jdbcType=BIGINT}, #{clientId,jdbcType=BIGINT}, #{clientName,jdbcType=VARCHAR}, | 
|---|
|  |  |  | 
|---|
|  |  |  | #{opEleTotalAmount,jdbcType=FLOAT}, #{opWaterRemainUser,jdbcType=FLOAT}, #{clDt,jdbcType=TIMESTAMP}, | 
|---|
|  |  |  | #{clType,jdbcType=TINYINT}, #{clTotalAmount,jdbcType=DOUBLE}, #{clIcCardNo,jdbcType=VARCHAR}, | 
|---|
|  |  |  | #{clIcCardAddr,jdbcType=VARCHAR}, #{clRemainMoney,jdbcType=DOUBLE}, #{clThisAmount,jdbcType=DOUBLE}, | 
|---|
|  |  |  | #{clThisMoney,jdbcType=DOUBLE}, #{clThisTime,jdbcType=INTEGER}, #{clOpenDt,jdbcType=TIMESTAMP}, | 
|---|
|  |  |  | #{closeDt,jdbcType=TIMESTAMP}, #{clOrderNo,jdbcType=VARCHAR}, #{clEleTotalAmount,jdbcType=FLOAT}, | 
|---|
|  |  |  | #{clWaterRemainUser,jdbcType=FLOAT}, #{clThisEle,jdbcType=FLOAT}) | 
|---|
|  |  |  | #{clThisMoney,jdbcType=DOUBLE}, #{clThisTime,jdbcType=INTEGER}, #{clPrice,jdbcType=INTEGER}, | 
|---|
|  |  |  | #{clOpenDt,jdbcType=TIMESTAMP}, #{closeDt,jdbcType=TIMESTAMP}, #{clOrderNo,jdbcType=VARCHAR}, | 
|---|
|  |  |  | #{clEleTotalAmount,jdbcType=FLOAT},#{clWaterRemainUser,jdbcType=FLOAT}, #{clThisEle,jdbcType=FLOAT}) | 
|---|
|  |  |  | </insert> | 
|---|
|  |  |  | <insert id="insertSelective" parameterType="com.dy.pipIrrGlobal.pojoRm.RmOpenCloseValveHistory"> | 
|---|
|  |  |  | <!--@mbg.generated--> | 
|---|
|  |  |  | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | <if test="clThisMoney != null"> | 
|---|
|  |  |  | cl_this_money, | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | <if test="clPrice != null"> | 
|---|
|  |  |  | cl_price, | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | <if test="clThisTime != null"> | 
|---|
|  |  |  | cl_this_time, | 
|---|
|  |  |  | 
|---|
|  |  |  | <if test="clThisTime != null"> | 
|---|
|  |  |  | #{clThisTime,jdbcType=INTEGER}, | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | <if test="clPrice != null"> | 
|---|
|  |  |  | #{clPrice,jdbcType=DOUBLE}, | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | <if test="clOpenDt != null"> | 
|---|
|  |  |  | #{clOpenDt,jdbcType=TIMESTAMP}, | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | 
|---|
|  |  |  | <if test="clThisTime != null"> | 
|---|
|  |  |  | cl_this_time = #{clThisTime,jdbcType=INTEGER}, | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | <if test="clPrice != null"> | 
|---|
|  |  |  | cl_price = #{clPrice,jdbcType=INTEGER}, | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | <if test="clOpenDt != null"> | 
|---|
|  |  |  | cl_open_dt = #{clOpenDt,jdbcType=TIMESTAMP}, | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | 
|---|
|  |  |  | cl_this_amount       = #{clThisAmount,jdbcType=DOUBLE}, | 
|---|
|  |  |  | cl_this_money        = #{clThisMoney,jdbcType=DOUBLE}, | 
|---|
|  |  |  | cl_this_time         = #{clThisTime,jdbcType=INTEGER}, | 
|---|
|  |  |  | cl_price             = #{clPrice,jdbcType=DOUBLE}, | 
|---|
|  |  |  | cl_open_dt           = #{clOpenDt,jdbcType=TIMESTAMP}, | 
|---|
|  |  |  | close_dt             = #{closeDt,jdbcType=TIMESTAMP}, | 
|---|
|  |  |  | cl_order_no          = #{clOrderNo,jdbcType=VARCHAR}, | 
|---|
|  |  |  | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!--根据指定条件获取开关阀报历史记录--> | 
|---|
|  |  |  | <select id="getOpenCloseValveReports_history" resultType="com.dy.pipIrrGlobal.voRm.VoOpenCloseValve"> | 
|---|
|  |  |  | SELECT oh.intake_id            AS intakeId, | 
|---|
|  |  |  | inta.name               AS intakenum, | 
|---|
|  |  |  | oh.rtu_addr             AS rtuAddr, | 
|---|
|  |  |  | oh.client_name          AS clientName, | 
|---|
|  |  |  | oh.op_ic_card_no        AS openIcNum, | 
|---|
|  |  |  | oh.op_ic_card_addr      AS openIcAddr, | 
|---|
|  |  |  | oh.open_dt              AS openTime, | 
|---|
|  |  |  | CASE | 
|---|
|  |  |  | <!--根据指定条件获取开关阀报历史记录 | 
|---|
|  |  |  | CASE | 
|---|
|  |  |  | WHEN oh.op_type = 1 THEN '刷卡开阀' | 
|---|
|  |  |  | WHEN oh.op_type = 3 THEN '中心站开阀' | 
|---|
|  |  |  | WHEN oh.op_type = 5 THEN '余额不足关阀' | 
|---|
|  |  |  | WHEN oh.op_type = 8 THEN '用户远程开阀' | 
|---|
|  |  |  | WHEN oh.op_type = 11 THEN '开关阀卡开阀' | 
|---|
|  |  |  | WHEN oh.op_type = 11 THEN '巡检卡开阀' | 
|---|
|  |  |  | ELSE '未知' | 
|---|
|  |  |  | END                 AS openType, | 
|---|
|  |  |  |  | 
|---|
|  |  |  | CASE | 
|---|
|  |  |  | WHEN oh.cl_type = 2 THEN '刷卡关阀' | 
|---|
|  |  |  | WHEN oh.cl_type = 4 THEN '中心站关阀' | 
|---|
|  |  |  | WHEN oh.cl_type = 5 THEN '余额不足关阀' | 
|---|
|  |  |  | WHEN oh.cl_type = 6 THEN '流量计故障关阀' | 
|---|
|  |  |  | WHEN oh.cl_type = 7 THEN '紧急关闭' | 
|---|
|  |  |  | WHEN oh.cl_type = 9 THEN '用户远程关阀' | 
|---|
|  |  |  | WHEN oh.cl_type = 10 THEN '巡检卡关阀' | 
|---|
|  |  |  | WHEN oh.cl_type = 12 THEN '黑名单命令关阀' | 
|---|
|  |  |  | WHEN oh.cl_type = 13 THEN '用户远程定时关阀' | 
|---|
|  |  |  | WHEN oh.cl_type = 14 THEN '用户远程定量关阀' | 
|---|
|  |  |  | ELSE '未知' | 
|---|
|  |  |  | END                 AS closeType, | 
|---|
|  |  |  | --> | 
|---|
|  |  |  | <select id="getOpenCloseValveReports_history" resultType="com.dy.pipIrrGlobal.voRm.VoOpenCloseValve"> | 
|---|
|  |  |  | SELECT oh.intake_id            AS intakeId, | 
|---|
|  |  |  | inta.name               AS intakenum, | 
|---|
|  |  |  | oh.rtu_addr             AS rtuAddr, | 
|---|
|  |  |  | cl.name                 AS clientName, | 
|---|
|  |  |  | cl.address              AS clientAddr, | 
|---|
|  |  |  | oh.op_ic_card_no        AS openIcNum, | 
|---|
|  |  |  | oh.op_ic_card_addr      AS openIcAddr, | 
|---|
|  |  |  | oh.open_dt              AS openTime, | 
|---|
|  |  |  | oh.op_type              AS opType, | 
|---|
|  |  |  | oh.op_order_no          AS openOrderNo, | 
|---|
|  |  |  | oh.op_total_amount      AS openTotalAmount, | 
|---|
|  |  |  | oh.op_remain_money      AS openRemainMoney, | 
|---|
|  |  |  | 
|---|
|  |  |  | oh.cl_ic_card_no        AS closeIcNum, | 
|---|
|  |  |  | oh.cl_ic_card_addr      AS closeIcAddr, | 
|---|
|  |  |  | oh.close_dt             AS closeTime, | 
|---|
|  |  |  | CASE | 
|---|
|  |  |  | WHEN oh.cl_type = 2 THEN '刷卡关阀' | 
|---|
|  |  |  | WHEN oh.cl_type = 4 THEN '中心站关阀' | 
|---|
|  |  |  | WHEN oh.cl_type = 5 THEN '余额不足关阀' | 
|---|
|  |  |  | WHEN oh.cl_type = 6 THEN '流量计故障关阀' | 
|---|
|  |  |  | WHEN oh.cl_type = 7 THEN '紧急关闭' | 
|---|
|  |  |  | WHEN oh.cl_type = 9 THEN '用户远程关阀' | 
|---|
|  |  |  | WHEN oh.cl_type = 10 THEN '开关阀卡关阀' | 
|---|
|  |  |  | WHEN oh.cl_type = 12 THEN '黑名单命令关阀' | 
|---|
|  |  |  | WHEN oh.cl_type = 13 THEN '用户远程定时关阀' | 
|---|
|  |  |  | WHEN oh.cl_type = 14 THEN '用户远程定量关阀' | 
|---|
|  |  |  | ELSE '未知' | 
|---|
|  |  |  | END                 AS closeType, | 
|---|
|  |  |  | oh.cl_type              AS clType, | 
|---|
|  |  |  | oh.cl_this_amount       AS closeThisAmount, | 
|---|
|  |  |  | oh.cl_this_time         AS thisTime, | 
|---|
|  |  |  | oh.cl_price             AS closePrice, | 
|---|
|  |  |  | oh.cl_this_money        AS thisMoney, | 
|---|
|  |  |  | oh.cl_remain_money      AS closeRemainMoney, | 
|---|
|  |  |  | oh.cl_total_amount      AS closeTotalAmount | 
|---|
|  |  |  | FROM rm_open_close_valve_history oh | 
|---|
|  |  |  | INNER JOIN pr_intake inta ON inta.id = oh.intake_id | 
|---|
|  |  |  | LEFT JOIN pr_intake inta ON inta.id = oh.intake_id | 
|---|
|  |  |  | LEFT JOIN se_client cl ON cl.id = oh.client_id | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="intakeId != null and intakeId > 0"> | 
|---|
|  |  |  | AND oh.intake_id = #{intakeId} | 
|---|
|  |  |  | 
|---|
|  |  |  | AND oh.cl_dt BETWEEN #{timeStart_close} AND #{timeStop_close} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | ORDER BY oh.op_dt DESC | 
|---|
|  |  |  | ORDER BY oh.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="getNeverOpenValveIntakesCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | SELECT COUNT(*) AS recordCount | 
|---|
|  |  |  | FROM pr_intake inta | 
|---|
|  |  |  | INNER JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | WHERE inta.deleted = 0 | 
|---|
|  |  |  | AND NOT EXISTS(SELECT * | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | WHERE op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | AND intake_id = inta.id) | 
|---|
|  |  |  | LEFT JOIN | 
|---|
|  |  |  | (SELECT intake_id FROM rm_open_close_valve_history | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test = "idStart != null"> | 
|---|
|  |  |  | id <![CDATA[>=]]> #{idStart} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | <if test = "idEnd != null"> | 
|---|
|  |  |  | AND id <![CDATA[<=]]> #{idEnd} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where>) his | 
|---|
|  |  |  | ON his.intake_id = inta.id | 
|---|
|  |  |  | LEFT JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | LEFT JOIN pr_controller pct ON inta.id = pct.intakeId | 
|---|
|  |  |  | WHERE his.intake_id IS NULL AND inta.deleted = 0 | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | <!--获取指定时间段内从未开过阀的取水口--> | 
|---|
|  |  |  | <select id="getNeverOpenValveIntakes" resultType="com.dy.pipIrrGlobal.voSt.VoIntake"> | 
|---|
|  |  |  | SELECT inta.id   AS intakeId, | 
|---|
|  |  |  | inta.name AS intakeNum, | 
|---|
|  |  |  | blo.name  AS blockName | 
|---|
|  |  |  | <select id="getNeverOpenValveIntakes" resultType="com.dy.pipIrrGlobal.voSt.VoIntakeUnOpenValve"> | 
|---|
|  |  |  | SELECT inta.id      AS intakeId, | 
|---|
|  |  |  | inta.name    AS intakeNum, | 
|---|
|  |  |  | inta.lng     AS lng, | 
|---|
|  |  |  | inta.lat     AS lat, | 
|---|
|  |  |  | blo.name     AS blockName, | 
|---|
|  |  |  | pct.rtuAddr  AS rtuAddr | 
|---|
|  |  |  | FROM pr_intake inta | 
|---|
|  |  |  | INNER JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | WHERE inta.deleted = 0 | 
|---|
|  |  |  | AND NOT EXISTS(SELECT * | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | WHERE op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | AND intake_id = inta.id) | 
|---|
|  |  |  | ORDER BY inta.id | 
|---|
|  |  |  | LEFT JOIN | 
|---|
|  |  |  | (SELECT intake_id FROM rm_open_close_valve_history | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test = "idStart != null"> | 
|---|
|  |  |  | id <![CDATA[>=]]> #{idStart} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | <if test = "idEnd != null"> | 
|---|
|  |  |  | AND id <![CDATA[<=]]> #{idEnd} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where>) his | 
|---|
|  |  |  | ON his.intake_id = inta.id | 
|---|
|  |  |  | LEFT JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | LEFT JOIN pr_controller pct ON inta.id = pct.intakeId | 
|---|
|  |  |  | WHERE his.intake_id IS NULL AND inta.deleted = 0 | 
|---|
|  |  |  | ORDER BY inta.id DESC | 
|---|
|  |  |  | <trim prefix="limit "> | 
|---|
|  |  |  | <if test="start != null and count != null"> | 
|---|
|  |  |  | #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER} | 
|---|
|  |  |  | 
|---|
|  |  |  | inta.name AS intakeNum, | 
|---|
|  |  |  | blo.name  AS blockName | 
|---|
|  |  |  | FROM pr_intake inta | 
|---|
|  |  |  | LEFT JOIN (SELECT * | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | WHERE op_dt BETWEEN #{timeStart} AND #{timeStop}) his ON his.intake_id = inta.id | 
|---|
|  |  |  | INNER JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | INNER JOIN (SELECT intake_id | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | WHERE id <![CDATA[>=]]> #{idStart} AND id <![CDATA[<=]]> #{idEnd} | 
|---|
|  |  |  | ) his ON his.intake_id = inta.id | 
|---|
|  |  |  | INNER JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | WHERE inta.deleted = 0 | 
|---|
|  |  |  | GROUP BY intakeId, intakeNum, blockName | 
|---|
|  |  |  | HAVING recordCount > #{value}) a | 
|---|
|  |  |  | 
|---|
|  |  |  | SELECT COUNT(*)  AS recordCount, | 
|---|
|  |  |  | inta.id   AS intakeId, | 
|---|
|  |  |  | inta.name AS intakeNum, | 
|---|
|  |  |  | inta.lng  AS lng, | 
|---|
|  |  |  | inta.lat  AS lat, | 
|---|
|  |  |  | blo.name  AS blockName | 
|---|
|  |  |  | FROM pr_intake inta | 
|---|
|  |  |  | LEFT JOIN (SELECT * | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | WHERE op_dt BETWEEN #{timeStart} AND #{timeStop}) his ON his.intake_id = inta.id | 
|---|
|  |  |  | INNER JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | INNER JOIN(SELECT intake_id | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | WHERE id <![CDATA[>=]]> #{idStart} AND id <![CDATA[<=]]> #{idEnd} | 
|---|
|  |  |  | ) his ON his.intake_id = inta.id | 
|---|
|  |  |  | INNER JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | WHERE inta.deleted = 0 | 
|---|
|  |  |  | GROUP BY intakeId, intakeNum, blockName | 
|---|
|  |  |  | HAVING recordCount > #{value} | 
|---|
|  |  |  | <!--        ORDER BY inta.id--> | 
|---|
|  |  |  | ORDER BY intakeId 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="getOpenValveLtIntakesCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | select count(*) | 
|---|
|  |  |  | 
|---|
|  |  |  | inta.name AS intakeNum, | 
|---|
|  |  |  | blo.name  AS blockName | 
|---|
|  |  |  | FROM pr_intake inta | 
|---|
|  |  |  | LEFT JOIN (SELECT * | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | WHERE op_dt BETWEEN #{timeStart} AND #{timeStop}) his ON his.intake_id = inta.id | 
|---|
|  |  |  | INNER JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | INNER JOIN (SELECT intake_id | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | WHERE id <![CDATA[>=]]> #{idStart} AND id <![CDATA[<=]]> #{idEnd} | 
|---|
|  |  |  | ) his ON his.intake_id = inta.id | 
|---|
|  |  |  | INNER JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | WHERE inta.deleted = 0 | 
|---|
|  |  |  | GROUP BY intakeId, intakeNum, blockName | 
|---|
|  |  |  | HAVING recordCount < #{value}) a | 
|---|
|  |  |  | 
|---|
|  |  |  | SELECT COUNT(*)  AS recordCount, | 
|---|
|  |  |  | inta.id   AS intakeId, | 
|---|
|  |  |  | inta.name AS intakeNum, | 
|---|
|  |  |  | inta.lng  AS lng, | 
|---|
|  |  |  | inta.lat  AS lat, | 
|---|
|  |  |  | blo.name  AS blockName | 
|---|
|  |  |  | FROM pr_intake inta | 
|---|
|  |  |  | LEFT JOIN (SELECT * | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | WHERE op_dt BETWEEN #{timeStart} AND #{timeStop}) his ON his.intake_id = inta.id | 
|---|
|  |  |  | INNER JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | INNER JOIN(SELECT intake_id | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | WHERE id <![CDATA[>=]]> #{idStart} AND id <![CDATA[<=]]> #{idEnd} | 
|---|
|  |  |  | ) his ON his.intake_id = inta.id | 
|---|
|  |  |  | INNER JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | WHERE inta.deleted = 0 | 
|---|
|  |  |  | GROUP BY intakeId, intakeNum, blockName | 
|---|
|  |  |  | HAVING recordCount < #{value} | 
|---|
|  |  |  | <!--        ORDER BY inta.id--> | 
|---|
|  |  |  | ORDER BY intakeId DESC | 
|---|
|  |  |  | <trim prefix="limit "> | 
|---|
|  |  |  | <if test="start != null and count != null"> | 
|---|
|  |  |  | #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER} | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!--获取指定时间段内开阀次数超过指定值的农户数量--> | 
|---|
|  |  |  | <select id="getLargeOpenCountClientsCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | SELECT COUNT(*) | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | inner join ( | 
|---|
|  |  |  | SELECT client_id, COUNT(*) AS openCount | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != ''"> | 
|---|
|  |  |  | op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | group by client_id | 
|---|
|  |  |  | <if test="openCount != null and openCount > 0"> | 
|---|
|  |  |  | having openCount > #{openCount} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | ) as his on his.client_id = cli.id | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | <!-- 2025-07-29 下面SQL查询太慢,废弃  --> | 
|---|
|  |  |  | <select id="_getLargeOpenCountClientsCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | SELECT COUNT(*) AS recordCount | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != '' and openCount != null"> | 
|---|
|  |  |  | (SELECT COUNT(*) | 
|---|
|  |  |  | FROM rm_open_close_valve_history his | 
|---|
|  |  |  | WHERE his.client_id = cli.id | 
|---|
|  |  |  | AND his.op_dt BETWEEN #{timeStart} AND #{timeStop}) > #{openCount} | 
|---|
|  |  |  | (SELECT COUNT(*) | 
|---|
|  |  |  | FROM rm_open_close_valve_history his | 
|---|
|  |  |  | WHERE his.client_id = cli.id | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != ''"> | 
|---|
|  |  |  | AND his.op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | ) > #{openCount} | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!--获取指定时间段内开阀次数超过指定值的农户--> | 
|---|
|  |  |  | <select id="getLargeOpenCountClients" resultType="com.dy.pipIrrGlobal.voSt.VoClient"> | 
|---|
|  |  |  | SELECT cli.id  AS clientId, | 
|---|
|  |  |  | cli.name       AS clientName, | 
|---|
|  |  |  | cli.clientNum, | 
|---|
|  |  |  | cli.address, | 
|---|
|  |  |  | cli.phone, | 
|---|
|  |  |  | cli.idCard, | 
|---|
|  |  |  | his.openCount | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | inner join ( | 
|---|
|  |  |  | SELECT client_id, COUNT(*) AS openCount | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != ''"> | 
|---|
|  |  |  | op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | group by client_id | 
|---|
|  |  |  | <if test="openCount != null and openCount > 0"> | 
|---|
|  |  |  | having openCount > #{openCount} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | ) as his on his.client_id = cli.id | 
|---|
|  |  |  | ORDER BY cli.id | 
|---|
|  |  |  | <trim prefix="limit "> | 
|---|
|  |  |  | <if test="start != null and count != null"> | 
|---|
|  |  |  | #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </trim> | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | <!-- 2025-07-29 下面SQL查询太慢,废弃  --> | 
|---|
|  |  |  | <select id="_getLargeOpenCountClients" resultType="com.dy.pipIrrGlobal.voSt.VoClient"> | 
|---|
|  |  |  | SELECT cli.id                                 AS clientId, | 
|---|
|  |  |  | cli.name                               AS clientName, | 
|---|
|  |  |  | cli.clientNum, | 
|---|
|  |  |  | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | his.client_id = cli.id | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != ''"> | 
|---|
|  |  |  | AND his.op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | AND his.op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where>) AS openCount | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != '' and openCount != null"> | 
|---|
|  |  |  | (SELECT COUNT(*) | 
|---|
|  |  |  | FROM rm_open_close_valve_history his | 
|---|
|  |  |  | WHERE his.client_id = cli.id | 
|---|
|  |  |  | AND his.op_dt BETWEEN #{timeStart} AND #{timeStop}) > #{openCount} | 
|---|
|  |  |  | (SELECT COUNT(*) | 
|---|
|  |  |  | FROM rm_open_close_valve_history his | 
|---|
|  |  |  | WHERE his.client_id = cli.id | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null"> | 
|---|
|  |  |  | AND his.op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | ) > #{openCount} | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | ORDER BY cli.id | 
|---|
|  |  |  | <trim prefix="limit "> | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!--获取指定时间段内开阀次数低于指定值的农户数量--> | 
|---|
|  |  |  | <select id="getSmallOpenCountClientsCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | SELECT COUNT(*) | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | inner join ( | 
|---|
|  |  |  | SELECT client_id, COUNT(*) AS openCount | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != ''"> | 
|---|
|  |  |  | op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | group by client_id | 
|---|
|  |  |  | <if test="openCount != null and openCount > 0"> | 
|---|
|  |  |  | having openCount < #{openCount} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | ) as his on his.client_id = cli.id | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | <!-- 2025-07-29 下面SQL查询太慢,废弃  --> | 
|---|
|  |  |  | <select id="_getSmallOpenCountClientsCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | SELECT COUNT(*) AS recordCount | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != '' and openCount != null"> | 
|---|
|  |  |  | (SELECT COUNT(*) | 
|---|
|  |  |  | FROM rm_open_close_valve_history his | 
|---|
|  |  |  | WHERE his.client_id = cli.id | 
|---|
|  |  |  | AND his.op_dt BETWEEN #{timeStart} AND #{timeStop}) < #{openCount} | 
|---|
|  |  |  | (SELECT COUNT(*) | 
|---|
|  |  |  | FROM rm_open_close_valve_history his | 
|---|
|  |  |  | WHERE his.client_id = cli.id | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != ''"> | 
|---|
|  |  |  | AND his.op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | <if test="openCount != null"> | 
|---|
|  |  |  | ) < #{openCount} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!--获取指定时间段内开阀次数低于指定值的农户--> | 
|---|
|  |  |  | <select id="getSmallOpenCountClients" resultType="com.dy.pipIrrGlobal.voSt.VoClient"> | 
|---|
|  |  |  | SELECT cli.id  AS clientId, | 
|---|
|  |  |  | cli.name       AS clientName, | 
|---|
|  |  |  | cli.clientNum, | 
|---|
|  |  |  | cli.address, | 
|---|
|  |  |  | cli.phone, | 
|---|
|  |  |  | cli.idCard, | 
|---|
|  |  |  | his.openCount | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | inner join ( | 
|---|
|  |  |  | SELECT client_id, COUNT(*) AS openCount | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != ''"> | 
|---|
|  |  |  | op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | group by client_id | 
|---|
|  |  |  | <if test="openCount != null and openCount > 0"> | 
|---|
|  |  |  | having openCount < #{openCount} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | ) as his on his.client_id = cli.id | 
|---|
|  |  |  | ORDER BY cli.id | 
|---|
|  |  |  | <trim prefix="limit "> | 
|---|
|  |  |  | <if test="start != null and count != null"> | 
|---|
|  |  |  | #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </trim> | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | <!-- 2025-07-29 下面SQL查询太慢,废弃  --> | 
|---|
|  |  |  | <select id="_getSmallOpenCountClients" resultType="com.dy.pipIrrGlobal.voSt.VoClient"> | 
|---|
|  |  |  | SELECT cli.id                                 AS clientId, | 
|---|
|  |  |  | cli.name                               AS clientName, | 
|---|
|  |  |  | cli.clientNum, | 
|---|
|  |  |  | 
|---|
|  |  |  | </where>) AS openCount | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != '' and openCount != null"> | 
|---|
|  |  |  | (SELECT COUNT(*) | 
|---|
|  |  |  | FROM rm_open_close_valve_history his | 
|---|
|  |  |  | WHERE his.client_id = cli.id | 
|---|
|  |  |  | AND his.op_dt BETWEEN #{timeStart} AND #{timeStop}) < #{openCount} | 
|---|
|  |  |  | (SELECT COUNT(*) | 
|---|
|  |  |  | FROM rm_open_close_valve_history his | 
|---|
|  |  |  | WHERE his.client_id = cli.id | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != ''"> | 
|---|
|  |  |  | AND his.op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | <if test="openCount != null"> | 
|---|
|  |  |  | < #{openCount} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | ORDER BY cli.id | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!--获取指定时间段内用水量超过指定值的农户数量--> | 
|---|
|  |  |  | <select id="getLargeWaterConsumptionClientsCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | SELECT COUNT(*) | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | inner join ( | 
|---|
|  |  |  | SELECT client_id, SUM(cl_this_amount) AS waterConsumption | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != ''"> | 
|---|
|  |  |  | op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | group by client_id | 
|---|
|  |  |  | <if test="waterConsumption != null and waterConsumption > 0"> | 
|---|
|  |  |  | having waterConsumption > #{waterConsumption} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | ) as his on his.client_id = cli.id | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | <!-- 2025-07-29 下面SQL查询太慢,废弃  --> | 
|---|
|  |  |  | <select id="_getLargeWaterConsumptionClientsCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | SELECT COUNT(*) AS recordCount | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!--获取指定时间段内用水量超过指定值的农户--> | 
|---|
|  |  |  | <select id="getLargeWaterConsumptionClients" resultType="com.dy.pipIrrGlobal.voSt.VoClient"> | 
|---|
|  |  |  | SELECT cli.id  AS clientId, | 
|---|
|  |  |  | cli.name       AS clientName, | 
|---|
|  |  |  | cli.clientNum, | 
|---|
|  |  |  | cli.address, | 
|---|
|  |  |  | cli.phone, | 
|---|
|  |  |  | cli.idCard, | 
|---|
|  |  |  | his.waterConsumption | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | inner join ( | 
|---|
|  |  |  | SELECT client_id, SUM(cl_this_amount) AS waterConsumption | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != ''"> | 
|---|
|  |  |  | op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | group by client_id | 
|---|
|  |  |  | <if test="waterConsumption != null and waterConsumption > 0"> | 
|---|
|  |  |  | having waterConsumption > #{waterConsumption} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | ) as his on his.client_id = cli.id | 
|---|
|  |  |  | ORDER BY cli.id | 
|---|
|  |  |  | <trim prefix="limit "> | 
|---|
|  |  |  | <if test="start != null and count != null"> | 
|---|
|  |  |  | #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </trim> | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | <!-- 2025-07-29 下面SQL查询太慢,废弃  --> | 
|---|
|  |  |  | <select id="_getLargeWaterConsumptionClients" resultType="com.dy.pipIrrGlobal.voSt.VoClient"> | 
|---|
|  |  |  | SELECT cli.id                                 AS clientId, | 
|---|
|  |  |  | cli.name                               AS clientName, | 
|---|
|  |  |  | cli.clientNum, | 
|---|
|  |  |  | 
|---|
|  |  |  | </trim> | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!--获取指定时间段内用水量低于指定值的农户数量--> | 
|---|
|  |  |  | <select id="getSmallWaterConsumptionClientsCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | SELECT COUNT(*) | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | inner join ( | 
|---|
|  |  |  | SELECT client_id, SUM(cl_this_amount) AS waterConsumption | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != ''"> | 
|---|
|  |  |  | op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | group by client_id | 
|---|
|  |  |  | <if test="waterConsumption != null and waterConsumption > 0"> | 
|---|
|  |  |  | having waterConsumption < #{waterConsumption} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | ) as his on his.client_id = cli.id | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | <!-- 2025-07-29 下面SQL查询太慢,废弃  --> | 
|---|
|  |  |  | <select id="_getSmallWaterConsumptionClientsCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | SELECT COUNT(*) AS recordCount | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != '' and waterConsumption != null"> | 
|---|
|  |  |  | (SELECT SUM(his.cl_this_amount) | 
|---|
|  |  |  | FROM rm_open_close_valve_history his | 
|---|
|  |  |  | WHERE his.client_id = cli.id | 
|---|
|  |  |  | AND his.op_dt BETWEEN #{timeStart} AND #{timeStop}) < #{waterConsumption} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!--获取指定时间段内用水量低于指定值的农户--> | 
|---|
|  |  |  | <select id="getSmallWaterConsumptionClients" resultType="com.dy.pipIrrGlobal.voSt.VoClient"> | 
|---|
|  |  |  | SELECT cli.id  AS clientId, | 
|---|
|  |  |  | cli.name       AS clientName, | 
|---|
|  |  |  | cli.clientNum, | 
|---|
|  |  |  | cli.address, | 
|---|
|  |  |  | cli.phone, | 
|---|
|  |  |  | cli.idCard, | 
|---|
|  |  |  | his.waterConsumption | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | inner join ( | 
|---|
|  |  |  | SELECT client_id, SUM(cl_this_amount) AS waterConsumption | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != ''"> | 
|---|
|  |  |  | op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | group by client_id | 
|---|
|  |  |  | <if test="waterConsumption != null and waterConsumption > 0"> | 
|---|
|  |  |  | having waterConsumption < #{waterConsumption} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | ) as his on his.client_id = cli.id | 
|---|
|  |  |  | ORDER BY cli.id | 
|---|
|  |  |  | <trim prefix="limit "> | 
|---|
|  |  |  | <if test="start != null and count != null"> | 
|---|
|  |  |  | #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </trim> | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | <!-- 2025-07-29 下面SQL查询太慢,废弃  --> | 
|---|
|  |  |  | <select id="_getSmallWaterConsumptionClients" resultType="com.dy.pipIrrGlobal.voSt.VoClient"> | 
|---|
|  |  |  | SELECT cli.id                                 AS clientId, | 
|---|
|  |  |  | cli.name                               AS clientName, | 
|---|
|  |  |  | cli.clientNum, | 
|---|
|  |  |  | CONCAT(cli.districtTitle, cli.address) AS address, | 
|---|
|  |  |  | cli.phone, | 
|---|
|  |  |  | cli.idCard, | 
|---|
|  |  |  | IFNULL((SELECT SUM(his.cl_this_amount) | 
|---|
|  |  |  | FROM rm_open_close_valve_history his | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | his.client_id = cli.id | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != ''"> | 
|---|
|  |  |  | AND his.op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | ),0) AS waterConsumption | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != '' and waterConsumption != null"> | 
|---|
|  |  |  | (SELECT SUM(his.cl_this_amount) | 
|---|
|  |  |  | FROM rm_open_close_valve_history his | 
|---|
|  |  |  | WHERE his.client_id = cli.id | 
|---|
|  |  |  | AND his.op_dt BETWEEN #{timeStart} AND #{timeStop}) < #{waterConsumption} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | ORDER BY cli.id | 
|---|
|  |  |  | <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="getLargeAmountSpentClientsCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | SELECT COUNT(*) | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | inner join ( | 
|---|
|  |  |  | SELECT client_id, SUM(cl_this_money) AS amountSpent | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != ''"> | 
|---|
|  |  |  | op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | group by client_id | 
|---|
|  |  |  | <if test="amountSpent != null and amountSpent > 0"> | 
|---|
|  |  |  | having amountSpent > #{amountSpent} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | ) as his on his.client_id = cli.id | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | <!-- 2025-07-29 下面SQL查询太慢,废弃  --> | 
|---|
|  |  |  | <select id="_getLargeAmountSpentClientsCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | SELECT COUNT(*) AS recordCount | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | <!--获取指定时间段内消费金额超过指定值的农户--> | 
|---|
|  |  |  | <select id="getLargeAmountSpentClients" resultType="com.dy.pipIrrGlobal.voSt.VoClient"> | 
|---|
|  |  |  | SELECT cli.id  AS clientId, | 
|---|
|  |  |  | cli.name       AS clientName, | 
|---|
|  |  |  | cli.clientNum, | 
|---|
|  |  |  | cli.address, | 
|---|
|  |  |  | cli.phone, | 
|---|
|  |  |  | cli.idCard, | 
|---|
|  |  |  | his.amountSpent | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | inner join ( | 
|---|
|  |  |  | SELECT client_id, SUM(cl_this_money) AS amountSpent | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != ''"> | 
|---|
|  |  |  | op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | group by client_id | 
|---|
|  |  |  | <if test="amountSpent != null and amountSpent > 0"> | 
|---|
|  |  |  | having amountSpent > #{amountSpent} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | ) as his on his.client_id = cli.id | 
|---|
|  |  |  | ORDER BY cli.id | 
|---|
|  |  |  | <trim prefix="limit "> | 
|---|
|  |  |  | <if test="start != null and count != null"> | 
|---|
|  |  |  | #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </trim> | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | <!-- 2025-07-29 下面SQL查询太慢,废弃  --> | 
|---|
|  |  |  | <select id="_getLargeAmountSpentClients" resultType="com.dy.pipIrrGlobal.voSt.VoClient"> | 
|---|
|  |  |  | SELECT cli.id                                 AS clientId, | 
|---|
|  |  |  | cli.name                               AS clientName, | 
|---|
|  |  |  | cli.clientNum, | 
|---|
|  |  |  | 
|---|
|  |  |  | </trim> | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!--获取指定时间段内消费金额低于指定值的农户数量--> | 
|---|
|  |  |  | <select id="getSmallAmountSpentClientsCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | SELECT COUNT(*) | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | inner join ( | 
|---|
|  |  |  | SELECT client_id, SUM(cl_this_money) AS amountSpent | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != ''"> | 
|---|
|  |  |  | op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | group by client_id | 
|---|
|  |  |  | <if test="amountSpent != null and amountSpent > 0"> | 
|---|
|  |  |  | having amountSpent < #{amountSpent} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | ) as his on his.client_id = cli.id | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | <!-- 2025-07-29 下面SQL查询太慢,废弃  --> | 
|---|
|  |  |  | <select id="_getSmallAmountSpentClientsCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | SELECT COUNT(*) AS recordCount | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != '' and amountSpent != null"> | 
|---|
|  |  |  | (SELECT SUM(his.cl_this_money) | 
|---|
|  |  |  | FROM rm_open_close_valve_history his | 
|---|
|  |  |  | WHERE his.client_id = cli.id | 
|---|
|  |  |  | AND his.op_dt BETWEEN #{timeStart} AND #{timeStop})  < #{amountSpent} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | <!--获取指定时间段内消费金额低于指定值的农户--> | 
|---|
|  |  |  | <select id="getSmallAmountSpentClients" resultType="com.dy.pipIrrGlobal.voSt.VoClient"> | 
|---|
|  |  |  | SELECT cli.id  AS clientId, | 
|---|
|  |  |  | cli.name       AS clientName, | 
|---|
|  |  |  | cli.clientNum, | 
|---|
|  |  |  | cli.address, | 
|---|
|  |  |  | cli.phone, | 
|---|
|  |  |  | cli.idCard, | 
|---|
|  |  |  | his.amountSpent | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | inner join ( | 
|---|
|  |  |  | SELECT client_id, SUM(cl_this_money) AS amountSpent | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != ''"> | 
|---|
|  |  |  | op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | group by client_id | 
|---|
|  |  |  | <if test="amountSpent != null and amountSpent > 0"> | 
|---|
|  |  |  | having amountSpent < #{amountSpent} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | ) as his on his.client_id = cli.id | 
|---|
|  |  |  | ORDER BY cli.id | 
|---|
|  |  |  | <trim prefix="limit "> | 
|---|
|  |  |  | <if test="start != null and count != null"> | 
|---|
|  |  |  | #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </trim> | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | <!-- 2025-07-29 下面SQL查询太慢,废弃  --> | 
|---|
|  |  |  | <select id="_getSmallAmountSpentClients" resultType="com.dy.pipIrrGlobal.voSt.VoClient"> | 
|---|
|  |  |  | SELECT cli.id                                 AS clientId, | 
|---|
|  |  |  | cli.name                               AS clientName, | 
|---|
|  |  |  | cli.clientNum, | 
|---|
|  |  |  | CONCAT(cli.districtTitle, cli.address) AS address, | 
|---|
|  |  |  | cli.phone, | 
|---|
|  |  |  | cli.idCard, | 
|---|
|  |  |  | IFNULL((SELECT SUM(his.cl_this_money) | 
|---|
|  |  |  | FROM rm_open_close_valve_history his | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | his.client_id = cli.id | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != ''"> | 
|---|
|  |  |  | AND his.op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | ),0) AS amountSpent | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != '' and amountSpent != null"> | 
|---|
|  |  |  | (SELECT SUM(his.cl_this_money) | 
|---|
|  |  |  | FROM rm_open_close_valve_history his | 
|---|
|  |  |  | WHERE his.client_id = cli.id | 
|---|
|  |  |  | AND his.op_dt BETWEEN #{timeStart} AND #{timeStop})  < #{amountSpent} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | ORDER BY cli.id | 
|---|
|  |  |  | <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="getLargeWaterDurationClientsCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | SELECT COUNT(*) | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | inner join ( | 
|---|
|  |  |  | SELECT client_id, SUM(cl_this_time) AS waterDuration | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != ''"> | 
|---|
|  |  |  | op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | group by client_id | 
|---|
|  |  |  | <if test="waterDuration != null and waterDuration > 0"> | 
|---|
|  |  |  | having waterDuration > #{waterDuration} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | ) as his on his.client_id = cli.id | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | <!-- 2025-07-29 下面SQL查询太慢,废弃  --> | 
|---|
|  |  |  | <select id="_getLargeWaterDurationClientsCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | SELECT COUNT(*) AS recordCount | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!--获取指定时间段内用水时长超过指定值的农户--> | 
|---|
|  |  |  | <select id="getLargeWaterDurationClients" resultType="com.dy.pipIrrGlobal.voSt.VoClient"> | 
|---|
|  |  |  | SELECT cli.id  AS clientId, | 
|---|
|  |  |  | cli.name       AS clientName, | 
|---|
|  |  |  | cli.clientNum, | 
|---|
|  |  |  | cli.address, | 
|---|
|  |  |  | cli.phone, | 
|---|
|  |  |  | cli.idCard, | 
|---|
|  |  |  | his.waterDuration | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | inner join ( | 
|---|
|  |  |  | SELECT client_id, SUM(cl_this_time) AS waterDuration | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != ''"> | 
|---|
|  |  |  | op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | group by client_id | 
|---|
|  |  |  | <if test="waterDuration != null and waterDuration > 0"> | 
|---|
|  |  |  | having waterDuration > #{waterDuration} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | ) as his on his.client_id = cli.id | 
|---|
|  |  |  | ORDER BY cli.id | 
|---|
|  |  |  | <trim prefix="limit "> | 
|---|
|  |  |  | <if test="start != null and count != null"> | 
|---|
|  |  |  | #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </trim> | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | <!-- 2025-07-29 下面SQL查询太慢,废弃  --> | 
|---|
|  |  |  | <select id="_getLargeWaterDurationClients" resultType="com.dy.pipIrrGlobal.voSt.VoClient"> | 
|---|
|  |  |  | SELECT cli.id                                 AS clientId, | 
|---|
|  |  |  | cli.name                               AS clientName, | 
|---|
|  |  |  | cli.clientNum, | 
|---|
|  |  |  | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </trim> | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | <!--指定时间段用水量超过指定值的取水口数量--> | 
|---|
|  |  |  | <select id="getUseWaterGtValueIntakesCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | select | 
|---|
|  |  |  | count(*) | 
|---|
|  |  |  | from | 
|---|
|  |  |  | (        SELECT | 
|---|
|  |  |  | inta.id AS intakeId, | 
|---|
|  |  |  | inta.NAME AS intakeNum, | 
|---|
|  |  |  | blo.NAME AS blockName , | 
|---|
|  |  |  | IFNULL(SUM(rocvh.cl_this_amount),0) AS value | 
|---|
|  |  |  | FROM | 
|---|
|  |  |  | pr_intake inta | 
|---|
|  |  |  | INNER JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | LEFT JOIN rm_open_close_valve_history rocvh ON rocvh.intake_id = inta.id | 
|---|
|  |  |  | WHERE rocvh.op_dt >= #{timeStart} AND rocvh.cl_dt <= #{timeStop} AND inta.deleted = 0 | 
|---|
|  |  |  | GROUP BY inta.id | 
|---|
|  |  |  | HAVING IFNULL(SUM(rocvh.cl_this_amount),0) > #{value}) c | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!--获取指定时间段内用水时长低于指定值的农户数量--> | 
|---|
|  |  |  | <select id="getSmallWaterDurationClientsCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | SELECT COUNT(*) | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | inner join ( | 
|---|
|  |  |  | SELECT client_id, SUM(cl_this_time) AS waterDuration | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != ''"> | 
|---|
|  |  |  | op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | group by client_id | 
|---|
|  |  |  | <if test="waterDuration != null and waterDuration > 0"> | 
|---|
|  |  |  | having waterDuration < #{waterDuration} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | ) as his on his.client_id = cli.id | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | <!--指定时间段用水量超过指定值的取水口--> | 
|---|
|  |  |  | <select id="getUseWaterGtValueIntakes" resultType="com.dy.pipIrrGlobal.voSt.VoIntakeAccumulateAmount"> | 
|---|
|  |  |  | SELECT | 
|---|
|  |  |  | inta.id AS intakeId, | 
|---|
|  |  |  | inta.NAME AS intakeNum, | 
|---|
|  |  |  | blo.NAME AS blockName , | 
|---|
|  |  |  | IFNULL(SUM(rocvh.cl_this_amount),0) AS value | 
|---|
|  |  |  | FROM | 
|---|
|  |  |  | pr_intake inta | 
|---|
|  |  |  | INNER JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | LEFT JOIN rm_open_close_valve_history rocvh ON rocvh.intake_id = inta.id | 
|---|
|  |  |  | WHERE rocvh.op_dt >= #{timeStart} AND rocvh.cl_dt <= #{timeStop} AND inta.deleted = 0 | 
|---|
|  |  |  | GROUP BY inta.id | 
|---|
|  |  |  | HAVING IFNULL(SUM(rocvh.cl_this_amount),0) > #{value} | 
|---|
|  |  |  | ORDER BY inta.id | 
|---|
|  |  |  | <trim prefix="limit " > | 
|---|
|  |  |  | <!-- 2025-07-29 下面SQL查询太慢,废弃  --> | 
|---|
|  |  |  | <select id="_getSmallWaterDurationClientsCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | SELECT COUNT(*) AS recordCount | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != '' and waterDuration != null"> | 
|---|
|  |  |  | (SELECT SUM(his.cl_this_time) | 
|---|
|  |  |  | FROM rm_open_close_valve_history his | 
|---|
|  |  |  | WHERE his.client_id = cli.id | 
|---|
|  |  |  | AND his.op_dt BETWEEN #{timeStart} AND #{timeStop})  < #{waterDuration} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!--获取指定时间段内用水时长低于指定值的农户--> | 
|---|
|  |  |  | <select id="getSmallWaterDurationClients" resultType="com.dy.pipIrrGlobal.voSt.VoClient"> | 
|---|
|  |  |  | SELECT cli.id  AS clientId, | 
|---|
|  |  |  | cli.name       AS clientName, | 
|---|
|  |  |  | cli.clientNum, | 
|---|
|  |  |  | cli.address, | 
|---|
|  |  |  | cli.phone, | 
|---|
|  |  |  | cli.idCard, | 
|---|
|  |  |  | his.waterDuration | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | inner join ( | 
|---|
|  |  |  | SELECT client_id, SUM(cl_this_time) AS waterDuration | 
|---|
|  |  |  | FROM rm_open_close_valve_history | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != ''"> | 
|---|
|  |  |  | op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | group by client_id | 
|---|
|  |  |  | <if test="waterDuration != null and waterDuration > 0"> | 
|---|
|  |  |  | having waterDuration < #{waterDuration} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | ) as his on his.client_id = cli.id | 
|---|
|  |  |  | ORDER BY cli.id | 
|---|
|  |  |  | <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="getExpenseGtValueIntakesCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | select | 
|---|
|  |  |  | count(*) | 
|---|
|  |  |  | from | 
|---|
|  |  |  | (        SELECT | 
|---|
|  |  |  | inta.id AS intakeId, | 
|---|
|  |  |  | inta.NAME AS intakeNum, | 
|---|
|  |  |  | blo.NAME AS blockName , | 
|---|
|  |  |  | IFNULL(SUM(rocvh.cl_this_money),0) AS value | 
|---|
|  |  |  | FROM | 
|---|
|  |  |  | pr_intake inta | 
|---|
|  |  |  | INNER JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | LEFT JOIN rm_open_close_valve_history rocvh ON rocvh.intake_id = inta.id | 
|---|
|  |  |  | WHERE rocvh.op_dt >= #{timeStart} AND rocvh.cl_dt <= #{timeStop} AND inta.deleted = 0 | 
|---|
|  |  |  | GROUP BY inta.id | 
|---|
|  |  |  | HAVING IFNULL(SUM(rocvh.cl_this_money),0) > #{value}) c | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | <!--指定时间段内消费金额超过指定值的取水口--> | 
|---|
|  |  |  | <select id="getExpenseGtValueIntakes" resultType="com.dy.pipIrrGlobal.voSt.VoIntakeAccumulateAmount"> | 
|---|
|  |  |  | SELECT | 
|---|
|  |  |  | inta.id AS intakeId, | 
|---|
|  |  |  | inta.NAME AS intakeNum, | 
|---|
|  |  |  | blo.NAME AS blockName , | 
|---|
|  |  |  | IFNULL(SUM(rocvh.cl_this_money),0) AS value | 
|---|
|  |  |  | FROM | 
|---|
|  |  |  | pr_intake inta | 
|---|
|  |  |  | INNER JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | LEFT JOIN rm_open_close_valve_history rocvh ON rocvh.intake_id = inta.id | 
|---|
|  |  |  | WHERE rocvh.op_dt >= #{timeStart} AND rocvh.cl_dt <= #{timeStop} AND inta.deleted = 0 | 
|---|
|  |  |  | GROUP BY inta.id | 
|---|
|  |  |  | HAVING IFNULL(SUM(rocvh.cl_this_money),0) > #{value} | 
|---|
|  |  |  | ORDER BY inta.id | 
|---|
|  |  |  | <trim prefix="limit " > | 
|---|
|  |  |  | <!-- 2025-07-29 下面SQL查询太慢,废弃  --> | 
|---|
|  |  |  | <select id="_getSmallWaterDurationClients" resultType="com.dy.pipIrrGlobal.voSt.VoClient"> | 
|---|
|  |  |  | SELECT cli.id                                 AS clientId, | 
|---|
|  |  |  | cli.name                               AS clientName, | 
|---|
|  |  |  | cli.clientNum, | 
|---|
|  |  |  | CONCAT(cli.districtTitle, cli.address) AS address, | 
|---|
|  |  |  | cli.phone, | 
|---|
|  |  |  | cli.idCard, | 
|---|
|  |  |  | IFNULL((SELECT SUM(his.cl_this_time) | 
|---|
|  |  |  | FROM rm_open_close_valve_history his | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | his.client_id = cli.id | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != ''"> | 
|---|
|  |  |  | AND his.op_dt BETWEEN #{timeStart} AND #{timeStop} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | ),0) AS waterDuration | 
|---|
|  |  |  | FROM se_client cli | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | <if test="timeStart != null and timeStart != '' and timeStop != null and timeStop != '' and waterDuration != null"> | 
|---|
|  |  |  | (SELECT SUM(his.cl_this_time) | 
|---|
|  |  |  | FROM rm_open_close_valve_history his | 
|---|
|  |  |  | WHERE his.client_id = cli.id | 
|---|
|  |  |  | AND his.op_dt BETWEEN #{timeStart} AND #{timeStop})  < #{waterDuration} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | ORDER BY cli.id | 
|---|
|  |  |  | <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="getUseWaterDurationGtValueIntakesCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | select | 
|---|
|  |  |  | 
|---|
|  |  |  | IFNULL(SUM(rocvh.cl_this_time),0) AS recordCount | 
|---|
|  |  |  | FROM | 
|---|
|  |  |  | pr_intake inta | 
|---|
|  |  |  | INNER JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | LEFT JOIN rm_open_close_valve_history rocvh ON rocvh.intake_id = inta.id | 
|---|
|  |  |  | LEFT JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | INNER JOIN rm_open_close_valve_history rocvh ON rocvh.intake_id = inta.id | 
|---|
|  |  |  | WHERE rocvh.op_dt >= #{timeStart} AND rocvh.cl_dt <= #{timeStop} AND inta.deleted = 0 | 
|---|
|  |  |  | GROUP BY inta.id | 
|---|
|  |  |  | HAVING IFNULL(SUM(rocvh.cl_this_time),0) > #{value} | 
|---|
|  |  |  | 
|---|
|  |  |  | <!--指定时间段 有开阀 无关阀的取水口数量--> | 
|---|
|  |  |  | <select id="getHaveOpenNoCloseIntakesCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | select count(*) from | 
|---|
|  |  |  | ( | 
|---|
|  |  |  | SELECT | 
|---|
|  |  |  | inta.id AS intakeId, | 
|---|
|  |  |  | inta.NAME AS intakeNum, | 
|---|
|  |  |  | blo.NAME AS blockName | 
|---|
|  |  |  | FROM | 
|---|
|  |  |  | pr_intake inta | 
|---|
|  |  |  | INNER JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | inner JOIN rm_open_close_valve_history rocvh ON rocvh.intake_id = inta.id | 
|---|
|  |  |  | WHERE rocvh.op_dt BETWEEN #{timeStart} AND  #{timeStop} AND rocvh.cl_dt IS NULL AND inta.deleted = 0 | 
|---|
|  |  |  | GROUP BY inta.id) c | 
|---|
|  |  |  | ( | 
|---|
|  |  |  | SELECT | 
|---|
|  |  |  | inta.id AS intakeId | 
|---|
|  |  |  | FROM | 
|---|
|  |  |  | pr_intake inta | 
|---|
|  |  |  | LEFT JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | INNER JOIN rm_open_close_valve_history rocvh ON rocvh.intake_id = inta.id | 
|---|
|  |  |  | WHERE inta.deleted = 0 AND rocvh.id <![CDATA[>=]]> #{idStart} AND  rocvh.id <![CDATA[<=]]> #{idEnd} AND rocvh.cl_dt IS NULL | 
|---|
|  |  |  | GROUP BY inta.id | 
|---|
|  |  |  | ) c | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | <!--指定时间段 有开阀 无关阀的取水口--> | 
|---|
|  |  |  | <select id="getHaveOpenNoCloseIntakes" resultType="com.dy.pipIrrGlobal.voSt.VoIntake"> | 
|---|
|  |  |  | SELECT | 
|---|
|  |  |  | inta.id AS intakeId, | 
|---|
|  |  |  | inta.NAME AS intakeNum, | 
|---|
|  |  |  | inta.lng AS lng, | 
|---|
|  |  |  | inta.lat AS lat, | 
|---|
|  |  |  | blo.NAME AS blockName | 
|---|
|  |  |  | FROM | 
|---|
|  |  |  | pr_intake inta | 
|---|
|  |  |  | INNER JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | inner JOIN rm_open_close_valve_history rocvh ON rocvh.intake_id = inta.id | 
|---|
|  |  |  | WHERE rocvh.op_dt BETWEEN #{timeStart} AND  #{timeStop} AND rocvh.cl_dt IS NULL AND inta.deleted = 0 | 
|---|
|  |  |  | LEFT JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | INNER JOIN rm_open_close_valve_history rocvh ON rocvh.intake_id = inta.id | 
|---|
|  |  |  | WHERE inta.deleted = 0 AND rocvh.id <![CDATA[>=]]> #{idStart} AND  rocvh.id <![CDATA[<=]]> #{idEnd} AND rocvh.cl_dt IS NULL | 
|---|
|  |  |  | GROUP BY inta.id | 
|---|
|  |  |  | ORDER BY inta.id | 
|---|
|  |  |  | ORDER BY inta.id DESC | 
|---|
|  |  |  | <trim prefix="limit "> | 
|---|
|  |  |  | <if test="start != null and count != null"> | 
|---|
|  |  |  | #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER} | 
|---|
|  |  |  | 
|---|
|  |  |  | <select id="getNoOpenHaveCloseIntakesCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | select count(*) from | 
|---|
|  |  |  | ( | 
|---|
|  |  |  | SELECT | 
|---|
|  |  |  | inta.id AS intakeId, | 
|---|
|  |  |  | inta.NAME AS intakeNum, | 
|---|
|  |  |  | blo.NAME AS blockName | 
|---|
|  |  |  | FROM | 
|---|
|  |  |  | pr_intake inta | 
|---|
|  |  |  | INNER JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | inner JOIN rm_open_close_valve_history rocvh ON rocvh.intake_id = inta.id | 
|---|
|  |  |  | WHERE rocvh.cl_dt BETWEEN #{timeStart} AND  #{timeStop} AND rocvh.op_dt IS NULL AND inta.deleted = 0 | 
|---|
|  |  |  | GROUP BY inta.id) c | 
|---|
|  |  |  | SELECT | 
|---|
|  |  |  | inta.id AS intakeId | 
|---|
|  |  |  | FROM | 
|---|
|  |  |  | pr_intake inta | 
|---|
|  |  |  | LEFT JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | INNER JOIN rm_open_close_valve_history rocvh ON rocvh.intake_id = inta.id | 
|---|
|  |  |  | WHERE inta.deleted = 0 AND rocvh.id <![CDATA[>=]]> #{idStart} AND  rocvh.id <![CDATA[<=]]> #{idEnd} AND rocvh.op_dt IS NULL | 
|---|
|  |  |  | GROUP BY inta.id | 
|---|
|  |  |  | ) c | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | <!--指定时间段 无开阀 有关阀的取水口--> | 
|---|
|  |  |  | <select id="getNoOpenHaveCloseIntakes" resultType="com.dy.pipIrrGlobal.voSt.VoIntake"> | 
|---|
|  |  |  | SELECT | 
|---|
|  |  |  | inta.id AS intakeId, | 
|---|
|  |  |  | inta.NAME AS intakeNum, | 
|---|
|  |  |  | inta.lng AS lng, | 
|---|
|  |  |  | inta.lat AS lat, | 
|---|
|  |  |  | blo.NAME AS blockName | 
|---|
|  |  |  | FROM | 
|---|
|  |  |  | pr_intake inta | 
|---|
|  |  |  | INNER JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | inner JOIN rm_open_close_valve_history rocvh ON rocvh.intake_id = inta.id | 
|---|
|  |  |  | WHERE rocvh.cl_dt BETWEEN #{timeStart} AND  #{timeStop} AND rocvh.op_dt IS NULL AND inta.deleted = 0 | 
|---|
|  |  |  | LEFT JOIN ba_block blo ON blo.id = inta.blockId | 
|---|
|  |  |  | INNER JOIN rm_open_close_valve_history rocvh ON rocvh.intake_id = inta.id | 
|---|
|  |  |  | WHERE inta.deleted = 0 AND rocvh.id <![CDATA[>=]]> #{idStart} AND  rocvh.id <![CDATA[<=]]> #{idEnd} AND rocvh.op_dt IS NULL | 
|---|
|  |  |  | GROUP BY inta.id | 
|---|
|  |  |  | ORDER BY inta.id | 
|---|
|  |  |  | ORDER BY inta.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="getCardOpenCloseCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | SELECT COUNT(*) AS recordCount | 
|---|
|  |  |  | FROM rm_open_close_valve_history his | 
|---|
|  |  |  | LEFT JOIN pr_intake inta ON inta.id = his.intake_id | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | AND op_type  = 1 | 
|---|
|  |  |  | <if test = "clientId != null"> | 
|---|
|  |  |  | AND his.client_id = #{clientId} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!--获取物理卡开关阀记录,微信小程序使用--> | 
|---|
|  |  |  | <select id="getCardOpenClose" resultType="com.dy.pipIrrGlobal.voRm.VoOpenClostWechat"> | 
|---|
|  |  |  | SELECT | 
|---|
|  |  |  | cl_this_money AS expense, | 
|---|
|  |  |  | op_ic_card_no AS cardNum, | 
|---|
|  |  |  | inta.name AS intakeNum, | 
|---|
|  |  |  | open_dt AS openTime, | 
|---|
|  |  |  | close_dt AS closeTime, | 
|---|
|  |  |  | cl_this_time AS duration, | 
|---|
|  |  |  | cl_this_amount AS amount, | 
|---|
|  |  |  | '刷卡开阀' AS openType | 
|---|
|  |  |  | FROM rm_open_close_valve_history his | 
|---|
|  |  |  | LEFT JOIN pr_intake inta ON inta.id = his.intake_id | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | AND op_type  = 1 | 
|---|
|  |  |  | <if test = "clientId != null"> | 
|---|
|  |  |  | AND his.client_id = #{clientId} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | ORDER BY open_dt 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="getVcCardOpenCloseCount" resultType="java.lang.Long"> | 
|---|
|  |  |  | SELECT COUNT(*) AS recordCount | 
|---|
|  |  |  | FROM rm_open_close_valve_history his | 
|---|
|  |  |  | LEFT JOIN pr_intake inta ON inta.id = his.intake_id | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | AND op_type  = 8 | 
|---|
|  |  |  | <if test = "clientId != null"> | 
|---|
|  |  |  | AND his.client_id = #{clientId} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!--获取虚拟卡开关阀记录,微信小程序使用--> | 
|---|
|  |  |  | <select id="getVcCardOpenClose" resultType="com.dy.pipIrrGlobal.voRm.VoOpenClostWechat"> | 
|---|
|  |  |  | SELECT | 
|---|
|  |  |  | cl_this_money AS expense, | 
|---|
|  |  |  | op_ic_card_no AS cardNum, | 
|---|
|  |  |  | inta.name AS intakeNum, | 
|---|
|  |  |  | open_dt AS openTime, | 
|---|
|  |  |  | close_dt AS closeTime, | 
|---|
|  |  |  | cl_this_time AS duration, | 
|---|
|  |  |  | cl_this_amount AS amount, | 
|---|
|  |  |  | CASE | 
|---|
|  |  |  | WHEN cl_type = 13 THEN '定时关阀式开阀' | 
|---|
|  |  |  | WHEN cl_type = 14 THEN '定量关阀式开阀' | 
|---|
|  |  |  | ELSE '远程开阀' | 
|---|
|  |  |  | END AS openType | 
|---|
|  |  |  | FROM rm_open_close_valve_history his | 
|---|
|  |  |  | LEFT JOIN pr_intake inta ON inta.id = his.intake_id | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | AND op_type  = 8 | 
|---|
|  |  |  | <if test = "clientId != null"> | 
|---|
|  |  |  | AND his.client_id = #{clientId} | 
|---|
|  |  |  | </if> | 
|---|
|  |  |  | </where> | 
|---|
|  |  |  | ORDER BY open_dt 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="statisticsByIc" resultType="com.dy.pipIrrGlobal.voSt.VoIcConsumeStatistics"> | 
|---|
|  |  |  | select ocvh.client_id as clientId, | 
|---|
|  |  |  | cc.id as cardId, | 
|---|
|  |  |  | sum(ocvh.cl_this_amount) as water, | 
|---|
|  |  |  | sum(ocvh.cl_this_money) as amount, | 
|---|
|  |  |  | sum(ocvh.cl_this_time) as duration, | 
|---|
|  |  |  | count(ocvh.id) as times | 
|---|
|  |  |  | from rm_open_close_valve_history ocvh | 
|---|
|  |  |  | inner join se_client_card cc on CAST(cc.cardNum AS CHAR) = ocvh.cl_ic_card_no | 
|---|
|  |  |  | where ocvh.cl_dt <![CDATA[>=]]> #{startDt, jdbcType=TIMESTAMP } | 
|---|
|  |  |  | and ocvh.cl_dt <![CDATA[<=]]> #{endDt, jdbcType=TIMESTAMP} | 
|---|
|  |  |  | group by ocvh.client_id, cc.id | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | <select id="statisticsByClient" resultType="com.dy.pipIrrGlobal.voSt.VoClientConsumeStatistics"> | 
|---|
|  |  |  | select client_id as clientId, | 
|---|
|  |  |  | sum(cl_this_amount) as water, | 
|---|
|  |  |  | sum(cl_this_money) as amount, | 
|---|
|  |  |  | sum(cl_this_time) as duration, | 
|---|
|  |  |  | count(id) as times | 
|---|
|  |  |  | from rm_open_close_valve_history | 
|---|
|  |  |  | where cl_dt <![CDATA[>=]]> #{startDt, jdbcType=TIMESTAMP} | 
|---|
|  |  |  | and cl_dt <![CDATA[<=]]> #{endDt, jdbcType=TIMESTAMP} | 
|---|
|  |  |  | group by client_id | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | </mapper> | 
|---|