From e059d06932a35d26be1c030dce61964bd04a1488 Mon Sep 17 00:00:00 2001 From: liurunyu <lry9898@163.com> Date: 星期四, 09 一月 2025 16:41:35 +0800 Subject: [PATCH] 优化”最近未上报数据“功能实现 --- pipIrr-platform/pipIrr-global/src/main/resources/mapper/RmOpenCloseValveHistoryMapper.xml | 109 ++++++++++++++++++++++++++++++------------------------ 1 files changed, 60 insertions(+), 49 deletions(-) diff --git a/pipIrr-platform/pipIrr-global/src/main/resources/mapper/RmOpenCloseValveHistoryMapper.xml b/pipIrr-platform/pipIrr-global/src/main/resources/mapper/RmOpenCloseValveHistoryMapper.xml index 8156a0d..efdb807 100644 --- a/pipIrr-platform/pipIrr-global/src/main/resources/mapper/RmOpenCloseValveHistoryMapper.xml +++ b/pipIrr-platform/pipIrr-global/src/main/resources/mapper/RmOpenCloseValveHistoryMapper.xml @@ -591,10 +591,11 @@ 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 + LEFT 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 @@ -604,22 +605,26 @@ 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 + LEFT 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> + <!--鑾峰彇鎸囧畾鏃堕棿娈靛唴寮�闃�娆℃暟浣庝簬鎸囧畾鍊肩殑鍙栨按鍙f暟閲�--> <select id="getOpenValveLtIntakesCount" resultType="java.lang.Long"> select count(*) @@ -628,10 +633,11 @@ 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 + LEFT 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 @@ -641,16 +647,19 @@ 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 + LEFT 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} @@ -1065,8 +1074,8 @@ 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} @@ -1080,31 +1089,32 @@ <!--鎸囧畾鏃堕棿娈� 鏈夊紑闃� 鏃犲叧闃�鐨勫彇姘村彛鏁伴噺--> <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} @@ -1115,30 +1125,31 @@ <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} -- Gitblit v1.8.0