| <?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.daoPr.PrIntakeControllerMapper"> | 
|   <resultMap id="BaseResultMap" type="com.dy.pipIrrGlobal.pojoPr.PrIntakeController"> | 
|     <!--@mbg.generated--> | 
|     <!--@Table pr_intake_controller--> | 
|     <id column="id" jdbcType="BIGINT" property="id" /> | 
|     <result column="intakeId" jdbcType="BIGINT" property="intakeid" /> | 
|     <result column="controllerId" jdbcType="BIGINT" property="controllerid" /> | 
|     <result column="operateType" jdbcType="TINYINT" property="operatetype" /> | 
|     <result column="remarks" jdbcType="VARCHAR" property="remarks" /> | 
|     <result column="operator" jdbcType="BIGINT" property="operator" /> | 
|     <result column="operateDt" jdbcType="TIMESTAMP" property="operatedt" /> | 
|   </resultMap> | 
|   <sql id="Base_Column_List"> | 
|     <!--@mbg.generated--> | 
|     id, intakeId, controllerId, operateType, remarks, `operator`, operateDt | 
|   </sql> | 
|   <select id="selectByPrimaryKey" parameterType="java.lang.Long" resultMap="BaseResultMap"> | 
|     <!--@mbg.generated--> | 
|     select  | 
|     <include refid="Base_Column_List" /> | 
|     from pr_intake_controller | 
|     where id = #{id,jdbcType=BIGINT} | 
|   </select> | 
|   <delete id="deleteByPrimaryKey" parameterType="java.lang.Long"> | 
|     <!--@mbg.generated--> | 
|     delete from pr_intake_controller | 
|     where id = #{id,jdbcType=BIGINT} | 
|   </delete> | 
|   | 
|   <insert id="insert" parameterType="com.dy.pipIrrGlobal.pojoPr.PrIntakeController"> | 
|     <!--@mbg.generated--> | 
|     insert into pr_intake_controller (id, intakeId, controllerId,  | 
|       operateType, remarks, `operator`,  | 
|       operateDt) | 
|     values (#{id,jdbcType=BIGINT}, #{intakeid,jdbcType=BIGINT}, #{controllerid,jdbcType=BIGINT},  | 
|       #{operatetype,jdbcType=TINYINT}, #{remarks,jdbcType=VARCHAR}, #{operator,jdbcType=BIGINT},  | 
|       #{operatedt,jdbcType=TIMESTAMP}) | 
|   </insert> | 
|   | 
|   <insert id="insertSelective" parameterType="com.dy.pipIrrGlobal.pojoPr.PrIntakeController"> | 
|     <!--@mbg.generated--> | 
|     insert into pr_intake_controller | 
|     <trim prefix="(" suffix=")" suffixOverrides=","> | 
|       <if test="id != null"> | 
|         id, | 
|       </if> | 
|       <if test="intakeid != null"> | 
|         intakeId, | 
|       </if> | 
|       <if test="controllerid != null"> | 
|         controllerId, | 
|       </if> | 
|       <if test="operatetype != null"> | 
|         operateType, | 
|       </if> | 
|       <if test="remarks != null"> | 
|         remarks, | 
|       </if> | 
|       <if test="operator != null"> | 
|         `operator`, | 
|       </if> | 
|       <if test="operatedt != null"> | 
|         operateDt, | 
|       </if> | 
|     </trim> | 
|     <trim prefix="values (" suffix=")" suffixOverrides=","> | 
|       <if test="id != null"> | 
|         #{id,jdbcType=BIGINT}, | 
|       </if> | 
|       <if test="intakeid != null"> | 
|         #{intakeid,jdbcType=BIGINT}, | 
|       </if> | 
|       <if test="controllerid != null"> | 
|         #{controllerid,jdbcType=BIGINT}, | 
|       </if> | 
|       <if test="operatetype != null"> | 
|         #{operatetype,jdbcType=TINYINT}, | 
|       </if> | 
|       <if test="remarks != null"> | 
|         #{remarks,jdbcType=VARCHAR}, | 
|       </if> | 
|       <if test="operator != null"> | 
|         #{operator,jdbcType=BIGINT}, | 
|       </if> | 
|       <if test="operatedt != null"> | 
|         #{operatedt,jdbcType=TIMESTAMP}, | 
|       </if> | 
|     </trim> | 
|   </insert> | 
|   <update id="updateByPrimaryKeySelective" parameterType="com.dy.pipIrrGlobal.pojoPr.PrIntakeController"> | 
|     <!--@mbg.generated--> | 
|     update pr_intake_controller | 
|     <set> | 
|       <if test="intakeid != null"> | 
|         intakeId = #{intakeid,jdbcType=BIGINT}, | 
|       </if> | 
|       <if test="controllerid != null"> | 
|         controllerId = #{controllerid,jdbcType=BIGINT}, | 
|       </if> | 
|       <if test="operatetype != null"> | 
|         operateType = #{operatetype,jdbcType=TINYINT}, | 
|       </if> | 
|       <if test="remarks != null"> | 
|         remarks = #{remarks,jdbcType=VARCHAR}, | 
|       </if> | 
|       <if test="operator != null"> | 
|         `operator` = #{operator,jdbcType=BIGINT}, | 
|       </if> | 
|       <if test="operatedt != null"> | 
|         operateDt = #{operatedt,jdbcType=TIMESTAMP}, | 
|       </if> | 
|     </set> | 
|     where id = #{id,jdbcType=BIGINT} | 
|   </update> | 
|   <update id="updateByPrimaryKey" parameterType="com.dy.pipIrrGlobal.pojoPr.PrIntakeController"> | 
|     <!--@mbg.generated--> | 
|     update pr_intake_controller | 
|     set intakeId = #{intakeid,jdbcType=BIGINT}, | 
|       controllerId = #{controllerid,jdbcType=BIGINT}, | 
|       operateType = #{operatetype,jdbcType=TINYINT}, | 
|       remarks = #{remarks,jdbcType=VARCHAR}, | 
|       `operator` = #{operator,jdbcType=BIGINT}, | 
|       operateDt = #{operatedt,jdbcType=TIMESTAMP} | 
|     where id = #{id,jdbcType=BIGINT} | 
|   </update> | 
|   | 
|   <!--根据取水口编号、控制器编号、操作类别获取记录数量--> | 
|   <select id="getBindRecordCount" resultType="java.lang.Integer"> | 
|     SELECT | 
|         COUNT(*) AS recordCount | 
|     FROM pr_intake_controller | 
|     <where> | 
|       <if test = "intakeId != null and intakeId > 0"> | 
|         AND intakeId = #{intakeId,jdbcType=BIGINT} | 
|       </if> | 
|   | 
|       <if test = "controllerId != null and controllerId > 0"> | 
|         AND controllerId = #{controllerId,jdbcType=BIGINT} | 
|       </if> | 
|   | 
|       <if test = "operateType != null and operateType > 0"> | 
|         AND operateType = #{operateType,jdbcType=BIGINT} | 
|       </if> | 
|     </where> | 
|   </select> | 
|   | 
|   <!--根据取水口编号获取绑定记录列表--> | 
|   <select id="getBindsByIntakeId" resultType="java.util.Map"> | 
|     SELECT | 
|         user.name AS userName, | 
|         <!--con.code AS controllerCode,--> | 
|         con.rtuAddr, | 
|         (CASE | 
|             WHEN ic.operateType = 1 THEN '绑定' | 
|             WHEN ic.operateType = 2 THEN '解绑' | 
|         END) AS operateType, | 
|         ic.operateDt | 
|     FROM pr_intake inta | 
|         INNER JOIN pr_intake_controller ic ON inta.id= ic.intakeId | 
|         INNER JOIN ba_user user ON ic.operator = user.id | 
|         INNER JOIN pr_controller con ON ic.controllerId = con.id | 
|     <if test = "intakeId != null"> | 
|       AND inta.id = #{intakeId,jdbcType=BIGINT} | 
|     </if> | 
|     ORDER BY ic.operateDt DESC | 
|   </select> | 
|   | 
|   <!--根据控制器编号获取绑定记录列表--> | 
|   <select id="getBindsByControllerId" resultType="java.util.Map"> | 
|     SELECT | 
|         (CASE | 
|             WHEN ic.operateType = 1 THEN '绑定' | 
|             WHEN ic.operateType = 2 THEN '解绑' | 
|         END) AS operateType, | 
|         inta.name AS intakeName, | 
|         user.name AS userName, | 
|         ic.operateDt | 
|     FROM pr_controller con | 
|         INNER JOIN pr_intake_controller ic ON ic.controllerId = con.id | 
|         INNER JOIN pr_intake inta ON ic.intakeId = inta.id | 
|         INNER JOIN ba_user user ON ic.operator = user.id | 
|     <if test = "controllerId != null"> | 
|       AND con.id = #{controllerId,jdbcType=BIGINT} | 
|     </if> | 
|     ORDER BY ic.operateDt DESC | 
|   </select> | 
|   | 
|   | 
|   <!--根据取水口编号修改绑定记录列表--> | 
|   <update id="updateByIntakeSelective"> | 
|     update pr_intake_controller | 
|     <set> | 
|       <if test="controllerid != null"> | 
|         controllerId = #{controllerid,jdbcType=BIGINT}, | 
|       </if> | 
|       <if test="operatetype != null"> | 
|         operateType = #{operatetype,jdbcType=TINYINT}, | 
|       </if> | 
|       <if test="remarks != null"> | 
|         remarks = #{remarks,jdbcType=VARCHAR}, | 
|       </if> | 
|       <if test="operator != null"> | 
|         `operator` = #{operator,jdbcType=BIGINT}, | 
|       </if> | 
|       <if test="operatedt != null"> | 
|         operateDt = #{operatedt,jdbcType=TIMESTAMP}, | 
|       </if> | 
|     </set> | 
|     where intakeId = #{intakeid,jdbcType=BIGINT} | 
|   </update> | 
| </mapper> |