灌溉计划表中增加项目ID字段,计划列表返回值中增加项目名称,项目状态改为整数表示
6个文件已修改
266 ■■■■■ 已修改文件
pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/daoIr/IrIrrigatePlanMapper.java 6 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/pojoIr/IrIrrigatePlan.java 5 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/voIr/VoPlans.java 7 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
pipIrr-platform/pipIrr-global/src/main/resources/mapper/IrIrrigatePlanMapper.xml 241 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
pipIrr-platform/pipIrr-web/pipIrr-web-wechat/src/main/java/com/dy/pipIrrWechat/irrigatePlan/IrrigatePlanCtrl.java 2 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
pipIrr-platform/pipIrr-web/pipIrr-web-wechat/src/main/java/com/dy/pipIrrWechat/irrigatePlan/dto/IrrigatePlan.java 5 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/daoIr/IrIrrigatePlanMapper.java
@@ -12,8 +12,8 @@
/**
 * @author ZhuBaoMin
 * @date 2025-02-25 14:59
 * @LastEditTime 2025-02-25 14:59
 * @date 2025-03-27 8:54
 * @LastEditTime 2025-03-27 8:54
 * @Description
 */
@@ -67,12 +67,14 @@
    /**
     * 获取未完成的计划列表,小程序计划列表页使用
     * 计划状态:1-草稿,2-未执行,3-执行中,4-已完成
     * @return
     */
    List<VoPlans> getNotCompletePlans();
    /**
     * 获取已完成的计划列表,小程序计划列表页使用
     * 计划状态:1-草稿,2-未执行,3-执行中,4-已完成
     * @return
     */
    List<VoPlans> getCompletedPlans();
pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/pojoIr/IrIrrigatePlan.java
@@ -36,6 +36,11 @@
    private Long id;
    /**
     * 项目ID
     */
    private Long projectId;
    /**
     * 计划名称
     */
    @NotBlank(message = "计划名称不能为空")
pipIrr-platform/pipIrr-global/src/main/java/com/dy/pipIrrGlobal/voIr/VoPlans.java
@@ -16,11 +16,16 @@
 */
@Data
@JsonPropertyOrder({"planId", "planName", "startupMode", "planStartTime", "planStopTime", "duration", "planState"})
@JsonPropertyOrder({"projectName","planId", "planName", "startupMode", "planStartTime", "planStopTime", "duration", "planState"})
public class VoPlans {
    public static final long serialVersionUID = 202503261555001L;
    /**
     * 项目名称
     */
    private String projectName;
    /**
     * 计划ID
     */
    @JSONField(serializeUsing= ObjectWriterImplToString.class)
pipIrr-platform/pipIrr-global/src/main/resources/mapper/IrIrrigatePlanMapper.xml
@@ -5,6 +5,7 @@
    <!--@mbg.generated-->
    <!--@Table ir_irrigate_plan-->
    <id column="id" jdbcType="BIGINT" property="id" />
    <result column="project_id" jdbcType="BIGINT" property="projectId" />
    <result column="plan_name" jdbcType="VARCHAR" property="planName" />
    <result column="startup_mode" jdbcType="TINYINT" property="startupMode" />
    <result column="plan_start_time" jdbcType="TIMESTAMP" property="planStartTime" />
@@ -16,7 +17,7 @@
  </resultMap>
  <sql id="Base_Column_List">
    <!--@mbg.generated-->
    id, plan_name, startup_mode, plan_start_time, plan_stop_time, duration,
    id, project_id, plan_name, startup_mode, plan_start_time, plan_stop_time, duration,
    plan_state, executing_state, deleted
  </sql>
  <select id="selectByPrimaryKey" parameterType="java.lang.Long" resultMap="BaseResultMap">
@@ -33,11 +34,11 @@
  </delete>
  <insert id="insert" parameterType="com.dy.pipIrrGlobal.pojoIr.IrIrrigatePlan">
    <!--@mbg.generated-->
    insert into ir_irrigate_plan (id, plan_name,
    insert into ir_irrigate_plan (id, project_id, plan_name,
      startup_mode, plan_start_time, plan_stop_time, 
      duration, plan_state, executing_state, 
      deleted)
    values (#{id,jdbcType=BIGINT}, #{planName,jdbcType=VARCHAR},
    values (#{id,jdbcType=BIGINT}, #{projectId,jdbcType=BIGINT}, #{planName,jdbcType=VARCHAR},
      #{startupMode,jdbcType=TINYINT}, #{planStartTime,jdbcType=TIMESTAMP}, #{planStopTime,jdbcType=TIMESTAMP}, 
      #{duration,jdbcType=INTEGER}, #{planState,jdbcType=TINYINT}, #{executingState,jdbcType=TINYINT}, 
      #{deleted,jdbcType=BIGINT})
@@ -48,6 +49,9 @@
    <trim prefix="(" suffix=")" suffixOverrides=",">
      <if test="id != null">
        id,
      </if>
      <if test="projectId != null">
        project_id,
      </if>
      <if test="planName != null">
        plan_name,
@@ -77,6 +81,9 @@
    <trim prefix="values (" suffix=")" suffixOverrides=",">
      <if test="id != null">
        #{id,jdbcType=BIGINT},
      </if>
      <if test="projectId != null">
        #{projectId,jdbcType=BIGINT},
      </if>
      <if test="planName != null">
        #{planName,jdbcType=VARCHAR},
@@ -108,6 +115,9 @@
    <!--@mbg.generated-->
    update ir_irrigate_plan
    <set>
      <if test="projectId != null">
        project_id = #{projectId,jdbcType=BIGINT},
      </if>
      <if test="planName != null">
        plan_name = #{planName,jdbcType=VARCHAR},
      </if>
@@ -138,7 +148,8 @@
  <update id="updateByPrimaryKey" parameterType="com.dy.pipIrrGlobal.pojoIr.IrIrrigatePlan">
    <!--@mbg.generated-->
    update ir_irrigate_plan
    set plan_name = #{planName,jdbcType=VARCHAR},
    set project_id = #{projectId,jdbcType=BIGINT},
      plan_name = #{planName,jdbcType=VARCHAR},
      startup_mode = #{startupMode,jdbcType=TINYINT},
      plan_start_time = #{planStartTime,jdbcType=TIMESTAMP},
      plan_stop_time = #{planStopTime,jdbcType=TIMESTAMP},
@@ -152,111 +163,111 @@
  <!--根据指定的计划ID获取启动模式-->
  <select id="getStartupMode" resultType="java.lang.Byte">
    SELECT
        startup_mode AS startupMode
    startup_mode AS startupMode
    FROM ir_irrigate_plan
    WHERE id = #{planId}
  </select>
  <!--根据指定的条件获取计划数量-->
<!--  <select id="getIrrigatePlanCount" resultType="java.lang.Long">-->
<!--    SELECT COUNT(*)-->
<!--    FROM ir_irrigate_plan plan-->
<!--    INNER JOIN ir_project pro ON pro.id = plan.project_id-->
<!--    <where>-->
<!--      AND plan.deleted = 0-->
<!--      AND pro.deleted = 0-->
<!--      <if test="projectName != null and projectName != ''">-->
<!--        AND pro.project_name LIKE CONCAT('%', #{projectName}, '%')-->
<!--      </if>-->
  <!--  <select id="getIrrigatePlanCount" resultType="java.lang.Long">-->
  <!--    SELECT COUNT(*)-->
  <!--    FROM ir_irrigate_plan plan-->
  <!--    INNER JOIN ir_project pro ON pro.id = plan.project_id-->
  <!--    <where>-->
  <!--      AND plan.deleted = 0-->
  <!--      AND pro.deleted = 0-->
  <!--      <if test="projectName != null and projectName != ''">-->
  <!--        AND pro.project_name LIKE CONCAT('%', #{projectName}, '%')-->
  <!--      </if>-->
<!--      <if test="planName != null and planName != ''">-->
<!--        AND plan.plan_name LIKE CONCAT('%', #{planName}, '%')-->
<!--      </if>-->
  <!--      <if test="planName != null and planName != ''">-->
  <!--        AND plan.plan_name LIKE CONCAT('%', #{planName}, '%')-->
  <!--      </if>-->
<!--      <if test="startupMode != null">-->
<!--        AND plan.startup_mode = #{startupMode}-->
<!--      </if>-->
  <!--      <if test="startupMode != null">-->
  <!--        AND plan.startup_mode = #{startupMode}-->
  <!--      </if>-->
<!--      <if test="planState != null">-->
<!--        AND plan.plan_state = #{planState}-->
<!--      </if>-->
  <!--      <if test="planState != null">-->
  <!--        AND plan.plan_state = #{planState}-->
  <!--      </if>-->
<!--      <if test="executingState != null">-->
<!--        AND plan.executing_state = #{executingState}-->
<!--      </if>-->
<!--    </where>-->
<!--  </select>-->
  <!--      <if test="executingState != null">-->
  <!--        AND plan.executing_state = #{executingState}-->
  <!--      </if>-->
  <!--    </where>-->
  <!--  </select>-->
  <!--根据指定的条件获取计划列表-->
<!--  <select id="getIrrigatePlans" resultType="com.dy.pipIrrGlobal.voIr.VoIrrigatePlan">-->
<!--    SELECT-->
<!--        plan.id AS planId,-->
<!--        pro.project_name AS projectName,-->
<!--        plan.plan_name AS planName,-->
<!--        CASE plan.startup_mode-->
<!--            WHEN 1 THEN '手动启动'-->
<!--            WHEN 2 THEN '自动启动'-->
<!--        END AS startupMode,-->
<!--        plan.plan_start_time AS startTime,-->
<!--        plan.plan_stop_time AS stopTime,-->
<!--        plan.duration AS duration,-->
<!--        CASE plan.plan_state-->
<!--            WHEN 1 THEN '草稿'-->
<!--            WHEN 2 THEN '已发布'-->
<!--        END AS planState,-->
  <!--  <select id="getIrrigatePlans" resultType="com.dy.pipIrrGlobal.voIr.VoIrrigatePlan">-->
  <!--    SELECT-->
  <!--        plan.id AS planId,-->
  <!--        pro.project_name AS projectName,-->
  <!--        plan.plan_name AS planName,-->
  <!--        CASE plan.startup_mode-->
  <!--            WHEN 1 THEN '手动启动'-->
  <!--            WHEN 2 THEN '自动启动'-->
  <!--        END AS startupMode,-->
  <!--        plan.plan_start_time AS startTime,-->
  <!--        plan.plan_stop_time AS stopTime,-->
  <!--        plan.duration AS duration,-->
  <!--        CASE plan.plan_state-->
  <!--            WHEN 1 THEN '草稿'-->
  <!--            WHEN 2 THEN '已发布'-->
  <!--        END AS planState,-->
<!--        CASE plan.executing_state-->
<!--            WHEN 1 THEN-->
<!--            '未执行'-->
<!--            WHEN 2 THEN-->
<!--            '执行中'-->
<!--            WHEN 3 THEN-->
<!--            '已暂停'-->
<!--            WHEN 4 THEN-->
<!--            '已终止'-->
<!--        END AS executingState-->
<!--    FROM ir_irrigate_plan plan-->
<!--    INNER JOIN ir_project pro ON pro.id = plan.project_id-->
<!--    <where>-->
<!--      AND plan.deleted = 0-->
<!--      AND pro.deleted = 0-->
<!--      <if test="projectName != null and projectName != ''">-->
<!--        AND pro.project_name LIKE CONCAT('%', #{projectName}, '%')-->
<!--      </if>-->
  <!--        CASE plan.executing_state-->
  <!--            WHEN 1 THEN-->
  <!--            '未执行'-->
  <!--            WHEN 2 THEN-->
  <!--            '执行中'-->
  <!--            WHEN 3 THEN-->
  <!--            '已暂停'-->
  <!--            WHEN 4 THEN-->
  <!--            '已终止'-->
  <!--        END AS executingState-->
  <!--    FROM ir_irrigate_plan plan-->
  <!--    INNER JOIN ir_project pro ON pro.id = plan.project_id-->
  <!--    <where>-->
  <!--      AND plan.deleted = 0-->
  <!--      AND pro.deleted = 0-->
  <!--      <if test="projectName != null and projectName != ''">-->
  <!--        AND pro.project_name LIKE CONCAT('%', #{projectName}, '%')-->
  <!--      </if>-->
<!--      <if test="planName != null and planName != ''">-->
<!--        AND plan.plan_name LIKE CONCAT('%', #{planName}, '%')-->
<!--      </if>-->
  <!--      <if test="planName != null and planName != ''">-->
  <!--        AND plan.plan_name LIKE CONCAT('%', #{planName}, '%')-->
  <!--      </if>-->
<!--      <if test="startupMode != null">-->
<!--        AND plan.startup_mode = #{startupMode}-->
<!--      </if>-->
  <!--      <if test="startupMode != null">-->
  <!--        AND plan.startup_mode = #{startupMode}-->
  <!--      </if>-->
<!--      <if test="planState != null">-->
<!--        AND plan.plan_state = #{planState}-->
<!--      </if>-->
  <!--      <if test="planState != null">-->
  <!--        AND plan.plan_state = #{planState}-->
  <!--      </if>-->
<!--      <if test="executingState != null">-->
<!--        AND plan.executing_state = #{executingState}-->
<!--      </if>-->
<!--    </where>-->
<!--    ORDER BY plan.plan_state DESC, plan.plan_start_time-->
<!--    <trim prefix="limit ">-->
<!--      <if test="start != null and count != null">-->
<!--        #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER}-->
<!--      </if>-->
<!--    </trim>-->
<!--  </select>-->
  <!--      <if test="executingState != null">-->
  <!--        AND plan.executing_state = #{executingState}-->
  <!--      </if>-->
  <!--    </where>-->
  <!--    ORDER BY plan.plan_state DESC, plan.plan_start_time-->
  <!--    <trim prefix="limit ">-->
  <!--      <if test="start != null and count != null">-->
  <!--        #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER}-->
  <!--      </if>-->
  <!--    </trim>-->
  <!--  </select>-->
  <!--根据计划ID获取计划简单信息-->
  <select id="getPlanSimple" resultType="com.dy.pipIrrGlobal.voIr.VoPlanSimple">
    SELECT
        plan.startup_mode AS startupMode,
        plan.plan_start_time AS planStartTime,
        plan.duration AS duration
    plan.startup_mode AS startupMode,
    plan.plan_start_time AS planStartTime,
    plan.duration AS duration
    FROM ir_irrigate_plan plan
    WHERE plan.id = #{planId}
      AND plan.deleted = 0 AND plan_state = 1
    AND plan.deleted = 0 AND plan_state = 1
    LIMIT 1
  </select>
@@ -270,39 +281,43 @@
  <!--获取未完成的计划列表,小程序计划列表页使用-->
  <select id="getNotCompletePlans" resultType="com.dy.pipIrrGlobal.voIr.VoPlans">
    SELECT
      id AS planId,
      plan_name AS planName,
      startup_mode AS startupMode,
      plan_start_time AS planStartTime,
      plan_stop_time AS planStopTime,
      duration,
      IF(plan_state = 1,'草稿',
         IF(NOW() &lt; plan_start_time, '未执行',
            IF(NOW() &gt;= plan_start_time AND NOW() &lt; plan_stop_time, '执行中', '已完成')
        )
      ) AS planState
      pro.project_name AS projectName,
      plan.id AS planId,
      plan.plan_name AS planName,
      plan.startup_mode AS startupMode,
      plan.plan_start_time AS planStartTime,
      plan.plan_stop_time AS planStopTime,
      plan.duration,
      IF(plan.plan_state = 1, 1,
         IF(NOW() &lt; plan.plan_start_time, 2,
            IF(NOW() &gt;= plan.plan_start_time AND NOW() &lt; plan.plan_stop_time, 3, 4)
           )
        ) AS planState
    FROM ir_irrigate_plan plan
    WHERE deleted = 0 AND (plan_state = 1 OR NOW() &lt; plan_stop_time)
    ORDER BY plan_state DESC
        INNER JOIN ir_project pro ON pro.id = plan.project_id
    WHERE plan.deleted = 0 AND (plan.plan_state = 1 OR NOW() &lt; plan.plan_stop_time)
    ORDER BY plan.plan_state DESC
  </select>
  <!--获取已完成的计划列表,小程序计划列表页使用-->
  <select id="getCompletedPlans" resultType="com.dy.pipIrrGlobal.voIr.VoPlans">
    SELECT
      id AS planId,
      plan_name AS planName,
      startup_mode AS startupMode,
      plan_start_time AS planStartTime,
      plan_stop_time AS planStopTime,
      duration,
      IF(plan_state = 1,'草稿',
         IF(NOW() &lt; plan_start_time, '未执行',
            IF(NOW() &gt;= plan_start_time AND NOW() &lt; plan_stop_time, '执行中', '已完成')
        )
      ) AS planState
      pro.project_name AS projectName,
      plan.id AS planId,
      plan.plan_name AS planName,
      plan.startup_mode AS startupMode,
      plan.plan_start_time AS planStartTime,
      plan.plan_stop_time AS planStopTime,
      plan.duration,
      IF(plan.plan_state = 1, 1,
         IF(NOW() &lt; plan.plan_start_time, 2,
            IF(NOW() &gt;= plan.plan_start_time AND NOW() &lt; plan.plan_stop_time, 3, 4)
           )
        ) AS planState
    FROM ir_irrigate_plan plan
    WHERE deleted = 0 AND (plan_state = 2 AND NOW() &gt;= plan_stop_time)
    ORDER BY plan_state DESC
        INNER JOIN ir_project pro ON pro.id = plan.project_id
    WHERE plan.deleted = 0 AND (plan.plan_state = 2 AND NOW() &gt;= plan.plan_stop_time)
    ORDER BY plan.plan_state DESC
  </select>
</mapper>
pipIrr-platform/pipIrr-web/pipIrr-web-wechat/src/main/java/com/dy/pipIrrWechat/irrigatePlan/IrrigatePlanCtrl.java
@@ -60,6 +60,7 @@
            return BaseResponseUtils.buildErrorMsg(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage());
        }
        Long projectId = planAndSchedule.getProjectId();
        Long operatorId = planAndSchedule.getOperatorId();
        Byte startupMode = planAndSchedule.getStartupMode();
        Date planStartTime = planAndSchedule.getPlanStartTime();;
@@ -94,6 +95,7 @@
        //planStopTime = Date.from(stopTime.atZone(ZoneId.systemDefault()).toInstant());
        IrIrrigatePlan plan = new IrIrrigatePlan();
        plan.setProjectId(projectId);
        plan.setPlanName(planAndSchedule.getPlanName());
        plan.setStartupMode(startupMode);
        plan.setPlanStartTime(planStartTime);
pipIrr-platform/pipIrr-web/pipIrr-web-wechat/src/main/java/com/dy/pipIrrWechat/irrigatePlan/dto/IrrigatePlan.java
@@ -18,6 +18,11 @@
    public static final long serialVersionUID = 202502201511001L;
    /**
     * 项目ID
     */
    private Long projectId;
    /**
     * 计划名称
     */
    @NotBlank(message = "计划名称不能为空")