From 1cf88d43994ec7ec403319032a9d118b39fe3571 Mon Sep 17 00:00:00 2001
From: liurunyu <lry9898@163.com>
Date: 星期五, 25 四月 2025 14:35:35 +0800
Subject: [PATCH] 登录代码优化

---
 pipIrr-platform/pipIrr-global/src/main/resources/mapper/IrIrrigateGroupMapper.xml |   81 ++++++++++++++++++++++++++++++++++++++--
 1 files changed, 77 insertions(+), 4 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 ec4bb00..5305c81 100644
--- a/pipIrr-platform/pipIrr-global/src/main/resources/mapper/IrIrrigateGroupMapper.xml
+++ b/pipIrr-platform/pipIrr-global/src/main/resources/mapper/IrIrrigateGroupMapper.xml
@@ -250,7 +250,8 @@
         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
+        pg.sort,
+        grp.operate_time
     FROM ir_irrigate_group grp
         LEFT JOIN ir_project_group pg ON pg.group_id = grp.id
     <where>
@@ -264,7 +265,7 @@
         AND grp.group_code LIKE CONCAT('%', #{groupCode}, '%')
       </if>
     </where>
-    ORDER BY grp.operate_time DESC
+    ORDER BY pg.sort
     <trim prefix="limit ">
       <if test="start != null and count != null">
         #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER}
@@ -295,8 +296,9 @@
     SELECT
         grp.id AS groupId,
         grp.group_code AS groupCode,
-        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,
+        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,
@@ -305,5 +307,76 @@
         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,-->
+        IF(
+            TIMESTAMPDIFF(MINUTE,
+            IF(#{terminateTime} > sche.start_time, sche.start_time, NULL),
+                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))
+            ) = 0, 1,
+            TIMESTAMPDIFF(MINUTE,
+                IF(#{terminateTime} > sche.start_time, sche.start_time, NULL),
+                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 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>
+
+  <!--鏍规嵁杞亴缁処D鑾峰彇杞亴缁勮鎯�-->
+  <select id="getGroupIntakes" resultType="com.dy.pipIrrGlobal.voIr.VoGroupIntakes">
+    SELECT
+      pro.project_name AS projectName,
+      gro.group_code AS groupName,
+      NULL AS intakes
+    FROM ir_irrigate_group gro
+           INNER JOIN ir_project_group pg ON pg.group_id = gro.id
+           INNER JOIN ir_project pro ON pro.id = pg.project_id
+    WHERE gro.deleted = 0 AND gro.id = #{groupId}
+  </select>
+
+  <!--鏍规嵁杞亴缁処D鑾峰彇杞亴缁勮鎯呭垪琛�-->
+  <select id="getGroupIntakesList" resultType="com.dy.pipIrrGlobal.voIr.VoIntake">
+    SELECT
+      con.rtuAddr,
+      inta.name AS intakeName,
+      NULL AS isOnLine
+    FROM ir_group_intake gi
+           INNER JOIN pr_intake inta ON inta.id = gi.intake_id
+           INNER JOIN pr_controller con ON con.intakeId = gi.intake_id
+    WHERE gi.group_id = #{groupId}
+  </select>
+  
+  <!--鏍规嵁杞亴缁勫悕绉扮粺璁¤褰曟暟-->
+  <select id="countByGroupCode" resultType="java.lang.Integer">
+    SELECT COUNT(*) 
+    FROM ir_irrigate_group 
+    WHERE group_code = #{groupCode} 
+    AND deleted = 0
+  </select>
+  
+  <!--鏍规嵁杞亴缁勫悕绉扮粺璁¤褰曟暟锛堟帓闄ゆ寚瀹欼D锛�-->
+  <select id="countByGroupCodeExcludeId" resultType="java.lang.Integer">
+    SELECT COUNT(*) 
+    FROM ir_irrigate_group 
+    WHERE group_code = #{groupCode} 
+    AND id != #{excludeId} 
+    AND deleted = 0
   </select>
 </mapper>
\ No newline at end of file

--
Gitblit v1.8.0