From 1e3eeec2d3a470d066d21900586b912dfef58c91 Mon Sep 17 00:00:00 2001
From: zhubaomin <zhubaomin>
Date: 星期四, 17 四月 2025 15:07:41 +0800
Subject: [PATCH] 优化代码

---
 pipIrr-platform/pipIrr-global/src/main/resources/mapper/IrIrrigateGroupMapper.xml |   85 +++++++++++++++++++++++-------------------
 1 files changed, 46 insertions(+), 39 deletions(-)

diff --git a/pipIrr-platform/pipIrr-global/src/main/resources/mapper/IrIrrigateGroupMapper.xml b/pipIrr-platform/pipIrr-global/src/main/resources/mapper/IrIrrigateGroupMapper.xml
index e91b8ae..5121d98 100644
--- a/pipIrr-platform/pipIrr-global/src/main/resources/mapper/IrIrrigateGroupMapper.xml
+++ b/pipIrr-platform/pipIrr-global/src/main/resources/mapper/IrIrrigateGroupMapper.xml
@@ -230,22 +230,8 @@
   <!--鏍规嵁鎸囧畾鏉′欢鑾峰彇杞亴缁勮褰曟暟-->
   <select id="getSimpleGroupCount" resultType="java.lang.Long">
     SELECT COUNT(*) AS recordCount
-<!--    FROM ir_irrigate_group grp-->
-<!--        INNER JOIN ir_project_group pg ON pg.group_id = grp.id-->
-<!--        INNER JOIN ir_project pro ON pg.project_id = pro.id-->
-<!--    <where>-->
-<!--      AND grp.deleted = 0-->
-
-<!--      <if test="projectId != null and projectId != ''">-->
-<!--        AND pro.id = #{projectId}-->
-<!--      </if>-->
-
-<!--      <if test="groupCode != null and groupCode != ''">-->
-<!--        AND grp.group_code LIKE CONCAT('%', #{groupCode}, '%')-->
-<!--      </if>-->
-<!--    </where>-->
     FROM ir_irrigate_group grp
-        INNER JOIN ir_project_group pg ON pg.group_id = grp.id
+        LEFT JOIN ir_project_group pg ON pg.group_id = grp.id
     <where>
       AND grp.deleted = 0
       <if test="projectId != null">
@@ -259,35 +245,15 @@
 
   <!--鏍规嵁鎸囧畾鏉′欢鑾峰彇杞亴缁勫垪琛�-->
   <select id="getSimpleGroups" resultType="com.dy.pipIrrGlobal.voIr.VoGroupSimple">
-<!--    SELECT-->
-<!--      grp.id AS groupId,-->
-<!--      grp.group_code AS groupCode,-->
-<!--      (SELECT COUNT(*) FROM ir_group_intake WHERE group_id = grp.id) AS intakeCount,-->
-<!--      grp.default_duration AS defaultDuration,-->
-<!--      pg.sort-->
-<!--    FROM ir_irrigate_group grp-->
-<!--           INNER JOIN ir_project_group pg ON pg.group_id = grp.id-->
-<!--           INNER JOIN ir_project pro ON pg.project_id = pro.id-->
-<!--    <where>-->
-<!--      AND grp.deleted = 0-->
-
-<!--      <if test="projectId != null and projectId != ''">-->
-<!--        AND pro.id = #{projectId}-->
-<!--      </if>-->
-
-<!--      <if test="groupCode != null and groupCode != ''">-->
-<!--        AND grp.group_code LIKE CONCAT('%', #{groupCode}, '%')-->
-<!--      </if>-->
-<!--    </where>-->
-<!--    ORDER BY pg.sort-->
-    SELECT
+    SELECT DISTINCT
         grp.id AS groupId,
         grp.group_code AS groupCode,
         (SELECT COUNT(*) FROM ir_group_intake WHERE group_id = grp.id) AS intakeCount,
         grp.default_duration AS defaultDuration,
-        0 as sort
+        0 as sort,
+        grp.operate_time
     FROM ir_irrigate_group grp
-        INNER JOIN ir_project_group pg ON pg.group_id = grp.id
+        LEFT JOIN ir_project_group pg ON pg.group_id = grp.id
     <where>
       AND grp.deleted = 0
 
@@ -325,4 +291,45 @@
       ) irrigateGroup
     GROUP BY groupCode,defaultDuration
   </select>
+
+  <select id="getGroupResult" resultType="com.dy.pipIrrGlobal.voIr.VoGroupResult">
+    SELECT
+        grp.id AS groupId,
+        grp.group_code AS groupCode,
+        IF(sche.current_state = 2, 5,
+            IF(NOW() &lt; sche.start_time, 2,
+                IF(NOW() > sche.start_time AND NOW() &lt; DATE_ADD(sche.start_time, INTERVAL sche.duration MINUTE), 3, 4))) AS state,
+        sche.start_time AS startTime,
+        DATE_ADD(sche.start_time, INTERVAL sche.duration MINUTE) AS stopTime,
+        sche.duration,
+        NULL AS publishResult
+    FROM ir_irrigate_group  grp
+        INNER JOIN ir_irrigate_schedule sche ON sche.group_id = grp.id
+        INNER JOIN ir_plan_schedule ps ON ps.schedule_id = sche.id
+    WHERE ps.plan_id = #{planId};
+
+  </select>
+
+  <!--鏍规嵁鐏屾簤璁″垝ID鑾峰彇杞亴缁勭粓姝㈢粨鏋�-->
+  <select id="getGroupResult_terminate" resultType="com.dy.pipIrrGlobal.voIr.VoGroupResult">
+    SELECT
+        grp.id AS groupId,
+        grp.group_code AS groupCode,
+        IF(#{terminateTime} &lt; sche.start_time, 6,
+            IF(#{terminateTime} &lt; DATE_ADD(sche.start_time, INTERVAL sche.duration MINUTE), 5, 4)) AS state,
+        IF(#{terminateTime} > sche.start_time, sche.start_time, NULL) AS startTime,
+            IF(#{terminateTime} > DATE_ADD(sche.start_time, INTERVAL sche.duration MINUTE), DATE_ADD(sche.start_time, INTERVAL sche.duration MINUTE),
+                IF(#{terminateTime} > sche.start_time, #{terminateTime}, NULL)) AS stopTime,
+        <!--sche.duration,-->
+        TIMESTAMPDIFF(MINUTE,
+            IF('2025-04-15 15:27' > sche.start_time, sche.start_time, NULL),
+            IF('2025-04-15 15:27' > DATE_ADD(sche.start_time, INTERVAL sche.duration MINUTE), DATE_ADD(sche.start_time, INTERVAL sche.duration MINUTE),
+                IF('2025-04-15 15:27' > sche.start_time, '2025-04-15 15:27', NULL))
+        ) AS duration,
+        NULL AS publishResult
+    FROM ir_irrigate_group  grp
+        INNER JOIN ir_irrigate_schedule sche ON sche.group_id = grp.id
+        INNER JOIN ir_plan_schedule ps ON ps.schedule_id = sche.id
+    WHERE ps.plan_id = #{planId}
+  </select>
 </mapper>
\ No newline at end of file

--
Gitblit v1.8.0