From 191ef9d695c421e8a1347cdfae312b6b633dfdc8 Mon Sep 17 00:00:00 2001 From: wuzeyu <1223318623@qq.com> Date: 星期二, 06 八月 2024 15:26:28 +0800 Subject: [PATCH] 查询指定时间段内用水量超过指定值的取水口 --- pipIrr-platform/pipIrr-global/src/main/resources/mapper/RmOnHourReportHistoryMapper.xml | 102 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 102 insertions(+), 0 deletions(-) diff --git a/pipIrr-platform/pipIrr-global/src/main/resources/mapper/RmOnHourReportHistoryMapper.xml b/pipIrr-platform/pipIrr-global/src/main/resources/mapper/RmOnHourReportHistoryMapper.xml index dab83eb..c3afb26 100644 --- a/pipIrr-platform/pipIrr-global/src/main/resources/mapper/RmOnHourReportHistoryMapper.xml +++ b/pipIrr-platform/pipIrr-global/src/main/resources/mapper/RmOnHourReportHistoryMapper.xml @@ -202,6 +202,9 @@ FROM rm_on_hour_report_history oh INNER JOIN pr_intake inta ON inta.id = oh.intake_id <where> + <if test="intakeId != null and intakeId >0"> + AND oh.intake_id = #{intakeId} + </if> <if test = "intakeName != null and intakeName !=''"> AND inta.name LIKE CONCAT('%',#{intakeName},'%') </if> @@ -231,6 +234,9 @@ FROM rm_on_hour_report_history oh INNER JOIN pr_intake inta ON inta.id = oh.intake_id <where> + <if test="intakeId != null and intakeId >0"> + AND oh.intake_id = #{intakeId} + </if> <if test = "intakeNum != null and intakeNum !=''"> AND inta.name LIKE CONCAT('%',#{intakeNum},'%') </if> @@ -248,4 +254,100 @@ </if> </trim> </select> + + <!--鑾峰彇鎸囧畾鏃堕棿娈靛唴鏈笂绾垮彇姘村彛鏁伴噺--> + <select id="getNotOnlineIntakesCount" resultType="java.lang.Long"> + SELECT + COUNT(*) AS recordCount + FROM pr_intake inta + LEFT JOIN (SELECT * FROM rm_on_hour_report_history WHERE dt BETWEEN #{timeStart} AND #{timeStop}) his ON his.intake_id = inta.id + INNER JOIN ba_block blo ON blo.id = inta.blockId + WHERE his.intake_id IS NULL AND inta.deleted = 0 + + </select> + + <!--鑾峰彇鎸囧畾鏃堕棿娈靛唴鏈笂绾跨殑鍙栨按鍙�--> + <select id="getNotOnlineIntakes" resultType="com.dy.pipIrrGlobal.voSt.VoIntake"> + SELECT + inta.id AS intakeId, + inta.name AS intakeNum, + blo.name AS blockName + FROM pr_intake inta + LEFT JOIN (SELECT * FROM rm_on_hour_report_history WHERE dt BETWEEN #{timeStart} AND #{timeStop}) his ON his.intake_id = inta.id + INNER JOIN ba_block blo ON blo.id = inta.blockId + WHERE his.intake_id IS NULL AND inta.deleted = 0 + ORDER BY inta.id + <trim prefix="limit " > + <if test="start != null and count != null"> + #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER} + </if> + </trim> + </select> + <!--鎸囧畾鏃堕棿娈靛唴鐢ㄦ按閲忚秴杩囨寚瀹氬�肩殑鍙栨按鍙f暟閲�--> + <select id="getUseWaterGtValueIntakesCount" resultType="java.lang.Long"> + select + count(*) + from + ( + SELECT + inta.id AS intakeId, + inta.NAME AS intakeNum, + blo.NAME AS blockName , + IFNULL(b.total_amount, 0)-IFNULL(a.total_amount, 0) AS value + FROM + pr_intake inta + INNER JOIN ba_block blo ON blo.id = inta.blockId + LEFT JOIN (SELECT + intake_id, + total_amount + FROM + rm_on_hour_report_history rohrs + WHERE rohrs.rtu_dt = ( SELECT MAX(rtu_dt) + FROM rm_on_hour_report_history + WHERE rtu_dt <= #{timeStart})) AS a ON inta.id = a.intake_id + LEFT JOIN ( SELECT + intake_id, + total_amount + FROM + rm_on_hour_report_history rohrs + WHERE rohrs.rtu_dt = ( SELECT MAX(rtu_dt) + FROM rm_on_hour_report_history + WHERE rtu_dt <= #{timeStop})) AS b ON inta.id = b.intake_id + WHERE IFNULL(b.total_amount, 0)-IFNULL(a.total_amount, 0) > #{value} AND inta.deleted = 0 + ) c + </select> + <!--鎸囧畾鏃堕棿娈靛唴鐢ㄦ按閲忚秴杩囨寚瀹氬�肩殑鍙栨按鍙�--> + <select id="getUseWaterGtValueIntakes" resultType="com.dy.pipIrrGlobal.voSt.VoIntakeAccumulateAmount"> + SELECT + inta.id AS intakeId, + inta.NAME AS intakeNum, + blo.NAME AS blockName , + IFNULL(b.total_amount, 0)-IFNULL(a.total_amount, 0) AS value + FROM + pr_intake inta + INNER JOIN ba_block blo ON blo.id = inta.blockId + LEFT JOIN (SELECT + intake_id, + total_amount + FROM + rm_on_hour_report_history rohrs + WHERE rohrs.rtu_dt = ( SELECT MAX(rtu_dt) + FROM rm_on_hour_report_history + WHERE rtu_dt <= #{timeStart})) AS a ON inta.id = a.intake_id + LEFT JOIN ( SELECT + intake_id, + total_amount + FROM + rm_on_hour_report_history rohrs + WHERE rohrs.rtu_dt = ( SELECT MAX(rtu_dt) + FROM rm_on_hour_report_history + WHERE rtu_dt <= #{timeStop})) AS b ON inta.id = b.intake_id + WHERE IFNULL(b.total_amount, 0)-IFNULL(a.total_amount, 0) > #{value} AND inta.deleted = 0 + ORDER BY inta.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> \ No newline at end of file -- Gitblit v1.8.0