<?xml version="1.0" encoding="UTF-8"?> 
 | 
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> 
 | 
<mapper namespace="com.dy.pipIrrGlobal.daoIr.IrIntakeOperateMapper"> 
 | 
  <resultMap id="BaseResultMap" type="com.dy.pipIrrGlobal.pojoIr.IrIntakeOperate"> 
 | 
    <!--@mbg.generated--> 
 | 
    <!--@Table ir_intake_operate--> 
 | 
    <id column="id" jdbcType="BIGINT" property="id" /> 
 | 
    <result column="plan_id" jdbcType="BIGINT" property="planId" /> 
 | 
    <result column="operate_type" jdbcType="TINYINT" property="operateType" /> 
 | 
    <result column="command_id" jdbcType="BIGINT" property="commandId" /> 
 | 
    <result column="intake_id" jdbcType="BIGINT" property="intakeId" /> 
 | 
    <result column="start_time" jdbcType="TIMESTAMP" property="startTime" /> 
 | 
    <result column="duration" jdbcType="INTEGER" property="duration" /> 
 | 
    <result column="command_result" jdbcType="TINYINT" property="commandResult" /> 
 | 
    <result column="failure_factors" jdbcType="VARCHAR" property="failureFactors" /> 
 | 
  </resultMap> 
 | 
  <sql id="Base_Column_List"> 
 | 
    <!--@mbg.generated--> 
 | 
    id, plan_id, operate_type, command_id, intake_id, start_time, duration, command_result,  
 | 
    failure_factors 
 | 
  </sql> 
 | 
  <select id="selectByPrimaryKey" parameterType="java.lang.Long" resultMap="BaseResultMap"> 
 | 
    <!--@mbg.generated--> 
 | 
    select  
 | 
    <include refid="Base_Column_List" /> 
 | 
    from ir_intake_operate 
 | 
    where id = #{id,jdbcType=BIGINT} 
 | 
  </select> 
 | 
  <delete id="deleteByPrimaryKey" parameterType="java.lang.Long"> 
 | 
    <!--@mbg.generated--> 
 | 
    delete from ir_intake_operate 
 | 
    where id = #{id,jdbcType=BIGINT} 
 | 
  </delete> 
 | 
  <insert id="insert" parameterType="com.dy.pipIrrGlobal.pojoIr.IrIntakeOperate"> 
 | 
    <!--@mbg.generated--> 
 | 
    insert into ir_intake_operate (id, plan_id, operate_type,  
 | 
      command_id, intake_id, start_time,  
 | 
      duration, command_result, failure_factors 
 | 
      ) 
 | 
    values (#{id,jdbcType=BIGINT}, #{planId,jdbcType=BIGINT}, #{operateType,jdbcType=TINYINT},  
 | 
      #{commandId,jdbcType=BIGINT}, #{intakeId,jdbcType=BIGINT}, #{startTime,jdbcType=TIMESTAMP},  
 | 
      #{duration,jdbcType=INTEGER}, #{commandResult,jdbcType=TINYINT}, #{failureFactors,jdbcType=VARCHAR} 
 | 
      ) 
 | 
  </insert> 
 | 
  <insert id="insertSelective" parameterType="com.dy.pipIrrGlobal.pojoIr.IrIntakeOperate"> 
 | 
    <!--@mbg.generated--> 
 | 
    insert into ir_intake_operate 
 | 
    <trim prefix="(" suffix=")" suffixOverrides=","> 
 | 
      <if test="id != null"> 
 | 
        id, 
 | 
      </if> 
 | 
      <if test="planId != null"> 
 | 
        plan_id, 
 | 
      </if> 
 | 
      <if test="operateType != null"> 
 | 
        operate_type, 
 | 
      </if> 
 | 
      <if test="commandId != null"> 
 | 
        command_id, 
 | 
      </if> 
 | 
      <if test="intakeId != null"> 
 | 
        intake_id, 
 | 
      </if> 
 | 
      <if test="startTime != null"> 
 | 
        start_time, 
 | 
      </if> 
 | 
      <if test="duration != null"> 
 | 
        duration, 
 | 
      </if> 
 | 
      <if test="commandResult != null"> 
 | 
        command_result, 
 | 
      </if> 
 | 
      <if test="failureFactors != null"> 
 | 
        failure_factors, 
 | 
      </if> 
 | 
    </trim> 
 | 
    <trim prefix="values (" suffix=")" suffixOverrides=","> 
 | 
      <if test="id != null"> 
 | 
        #{id,jdbcType=BIGINT}, 
 | 
      </if> 
 | 
      <if test="planId != null"> 
 | 
        #{planId,jdbcType=BIGINT}, 
 | 
      </if> 
 | 
      <if test="operateType != null"> 
 | 
        #{operateType,jdbcType=TINYINT}, 
 | 
      </if> 
 | 
      <if test="commandId != null"> 
 | 
        #{commandId,jdbcType=BIGINT}, 
 | 
      </if> 
 | 
      <if test="intakeId != null"> 
 | 
        #{intakeId,jdbcType=BIGINT}, 
 | 
      </if> 
 | 
      <if test="startTime != null"> 
 | 
        #{startTime,jdbcType=TIMESTAMP}, 
 | 
      </if> 
 | 
      <if test="duration != null"> 
 | 
        #{duration,jdbcType=INTEGER}, 
 | 
      </if> 
 | 
      <if test="commandResult != null"> 
 | 
        #{commandResult,jdbcType=TINYINT}, 
 | 
      </if> 
 | 
      <if test="failureFactors != null"> 
 | 
        #{failureFactors,jdbcType=VARCHAR}, 
 | 
      </if> 
 | 
    </trim> 
 | 
  </insert> 
 | 
  <update id="updateByPrimaryKeySelective" parameterType="com.dy.pipIrrGlobal.pojoIr.IrIntakeOperate"> 
 | 
    <!--@mbg.generated--> 
 | 
    update ir_intake_operate 
 | 
    <set> 
 | 
      <if test="planId != null"> 
 | 
        plan_id = #{planId,jdbcType=BIGINT}, 
 | 
      </if> 
 | 
      <if test="operateType != null"> 
 | 
        operate_type = #{operateType,jdbcType=TINYINT}, 
 | 
      </if> 
 | 
      <if test="commandId != null"> 
 | 
        command_id = #{commandId,jdbcType=BIGINT}, 
 | 
      </if> 
 | 
      <if test="intakeId != null"> 
 | 
        intake_id = #{intakeId,jdbcType=BIGINT}, 
 | 
      </if> 
 | 
      <if test="startTime != null"> 
 | 
        start_time = #{startTime,jdbcType=TIMESTAMP}, 
 | 
      </if> 
 | 
      <if test="duration != null"> 
 | 
        duration = #{duration,jdbcType=INTEGER}, 
 | 
      </if> 
 | 
      <if test="commandResult != null"> 
 | 
        command_result = #{commandResult,jdbcType=TINYINT}, 
 | 
      </if> 
 | 
      <if test="failureFactors != null"> 
 | 
        failure_factors = #{failureFactors,jdbcType=VARCHAR}, 
 | 
      </if> 
 | 
    </set> 
 | 
    where id = #{id,jdbcType=BIGINT} 
 | 
  </update> 
 | 
  <update id="updateByPrimaryKey" parameterType="com.dy.pipIrrGlobal.pojoIr.IrIntakeOperate"> 
 | 
    <!--@mbg.generated--> 
 | 
    update ir_intake_operate 
 | 
    set plan_id = #{planId,jdbcType=BIGINT}, 
 | 
      operate_type = #{operateType,jdbcType=TINYINT}, 
 | 
      command_id = #{commandId,jdbcType=BIGINT}, 
 | 
      intake_id = #{intakeId,jdbcType=BIGINT}, 
 | 
      start_time = #{startTime,jdbcType=TIMESTAMP}, 
 | 
      duration = #{duration,jdbcType=INTEGER}, 
 | 
      command_result = #{commandResult,jdbcType=TINYINT}, 
 | 
      failure_factors = #{failureFactors,jdbcType=VARCHAR} 
 | 
    where id = #{id,jdbcType=BIGINT} 
 | 
  </update> 
 | 
  
 | 
  <!--根据命令ID更新取水口操作记录--> 
 | 
  <update id="updateByCommandId" > 
 | 
    update ir_intake_operate 
 | 
    set command_result = #{commandResult}, failure_factors = #{failureFactors} 
 | 
    where command_id = #{commandId} 
 | 
  </update> 
 | 
  
 | 
  <!--根据计划ID获取待终止的取水口ID(已发布开发命令,无论是否成功)--> 
 | 
  <select id="getToTerminateIntakeIds" resultType="java.lang.Long"> 
 | 
    SELECT 
 | 
      intake_id AS intakeId 
 | 
    FROM ir_intake_operate 
 | 
    WHERE operate_type = 1 AND plan_id = #{planId} 
 | 
  </select> 
 | 
  
 | 
  <!--根据计划ID获取待终止的命令ID--> 
 | 
  <select id="getTerminateCommandIds" resultType="java.lang.Long"> 
 | 
    SELECT command_id AS commandId FROM ir_intake_operate WHERE operate_type = 1 AND plan_id = #{planId} 
 | 
  </select> 
 | 
  
 | 
  <!--根据计划ID获取待终止的取水口列表(开阀成功的)--> 
 | 
  <select id="getToTerminateIntakes" resultType="com.dy.pipIrrGlobal.voIr.VoToTerminateIntakes"> 
 | 
    SELECT 
 | 
      command_id AS commandId, 
 | 
      intake_id AS intakeId, 
 | 
      start_time AS startTime 
 | 
    FROM ir_intake_operate 
 | 
    WHERE operate_type = 1 AND command_result = 1 AND plan_id = #{planId} 
 | 
  </select> 
 | 
  
 | 
  <!--根据计划ID及管轮组ID获取取水口发布发布结果--> 
 | 
  <select id="getIntakeResult" resultType="com.dy.pipIrrGlobal.voIr.VoIntakeResult"> 
 | 
    SELECT 
 | 
        IF(io.command_result = 1, 0, 1) AS code, 
 | 
        (SELECT name FROM pr_intake WHERE id = io.intake_id) AS intakeName, 
 | 
        io.failure_factors AS result 
 | 
    FROM ir_intake_operate io 
 | 
        inner JOIN ir_group_intake gi ON gi.intake_id = io.intake_id 
 | 
    WHERE io.plan_id = #{planId} AND gi.group_id = #{groupId} AND operate_type = 1; 
 | 
  </select> 
 | 
  
 | 
  <!--根据计划ID获取取水口命令发布失败数量,灌溉计划详情页使用--> 
 | 
  <select id="getFailureCount" resultType="java.lang.Integer"> 
 | 
    SELECT 
 | 
      COUNT(1) AS failureCount 
 | 
    FROM ir_intake_operate 
 | 
    WHERE operate_type = 1 AND command_result != 1 AND plan_id = #{planId} 
 | 
  </select> 
 | 
</mapper> 
 |