pipIrr-platform/pipIrr-global/src/main/resources/mapper/RmOpenCloseValveHistoryMapper.xml
@@ -786,4 +786,90 @@
            </if>
        </trim>
    </select>
    <!--获取指定时间段内用水量超过指定值的农户数量-->
    <select id="getLargeWaterConsumptionClientsCount" resultType="java.lang.Long">
        SELECT COUNT(*) AS recordCount
        FROM se_client cli
                 INNER JOIN rm_open_close_valve_history his ON his.client_id = cli.id
        WHERE his.op_dt BETWEEN #{timeStart} AND #{timeStop}
          AND his.cl_this_amount > #{waterConsumption}
    </select>
    <!--获取指定时间段内用水量超过指定值的农户-->
    <select id="getLargeWaterConsumptionClients" 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
        FROM se_client cli
                 INNER JOIN rm_open_close_valve_history his ON his.client_id = cli.id
        WHERE his.op_dt BETWEEN #{timeStart} AND #{timeStop}
          AND his.cl_this_amount > #{waterConsumption}
        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(*) AS recordCount
        FROM se_client cli
                 INNER JOIN rm_open_close_valve_history his ON his.client_id = cli.id
        WHERE his.op_dt BETWEEN #{timeStart} AND #{timeStop}
          AND his.cl_this_money > #{amountSpent}
    </select>
    <!--获取指定时间段内消费金额超过指定值的农户-->
    <select id="getLargeAmountSpentClients" 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
        FROM se_client cli
                 INNER JOIN rm_open_close_valve_history his ON his.client_id = cli.id
        WHERE his.op_dt BETWEEN #{timeStart} AND #{timeStop}
          AND his.cl_this_money > #{amountSpent}
        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(*) AS recordCount
        FROM se_client cli
                 INNER JOIN rm_open_close_valve_history his ON his.client_id = cli.id
        WHERE his.op_dt BETWEEN #{timeStart} AND #{timeStop}
          AND his.cl_this_time > #{waterDuration}
    </select>
    <!--获取指定时间段内用水时长超过指定值的农户-->
    <select id="getLargeWaterDurationClients" 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
        FROM se_client cli
                 INNER JOIN rm_open_close_valve_history his ON his.client_id = cli.id
        WHERE his.op_dt BETWEEN #{timeStart} AND #{timeStop}
          AND his.cl_this_time > #{waterDuration}
        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>
</mapper>