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() < sche.start_time, 2, - IF(NOW() > sche.start_time AND NOW() < DATE_ADD(sche.start_time, INTERVAL sche.duration MINUTE), 3, 4)) AS state, + IF(sche.current_state = 2, 5, + IF(NOW() < sche.start_time, 2, + IF(NOW() > sche.start_time AND NOW() < 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} < sche.start_time, 6, + IF(#{terminateTime} < 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