|  |  |  | 
|---|
|  |  |  | where com_id = #{comId,jdbcType=BIGINT} | 
|---|
|  |  |  | </update> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!--根据操作员ID获取未关阀记录(包含在线情况)--> | 
|---|
|  |  |  | <!--根据operator获取未关阀的RTU地址及虚拟卡编号数据对,获取未关阀记录使用--> | 
|---|
|  |  |  | <select id="getUnclosedRtus" resultType="com.dy.pipIrrGlobal.voRm.VoRtuAndVc"> | 
|---|
|  |  |  | SELECT | 
|---|
|  |  |  | com.rtu_addr AS rtuAddr, | 
|---|
|  |  |  | com.param ->> '$.icCardNo' AS vcNum | 
|---|
|  |  |  | FROM rm_command_history com | 
|---|
|  |  |  | where 1=1 | 
|---|
|  |  |  | AND com.operator = #{operator} | 
|---|
|  |  |  | AND com.result = 1 | 
|---|
|  |  |  | AND ((com.protocol = 'p206V1' OR com.protocol = 'p206V2') AND (com.command_code = '92' OR com.command_code = '97' OR com.command_code = '99' OR com.command_code = 'A0' OR com.command_code = 'A1' OR com.command_code = 'A2')) | 
|---|
|  |  |  | AND ( | 
|---|
|  |  |  | SELECT op_dt FROM rm_open_close_valve_last | 
|---|
|  |  |  | WHERE rtu_addr = com.rtu_addr AND op_ic_card_no = com.param ->> '$.icCardNo' | 
|---|
|  |  |  | ORDER BY op_dt DESC | 
|---|
|  |  |  | LIMIT 1 | 
|---|
|  |  |  | ) IS NOT NULL | 
|---|
|  |  |  | AND ( | 
|---|
|  |  |  | SELECT cl_dt FROM rm_open_close_valve_last | 
|---|
|  |  |  | WHERE rtu_addr = com.rtu_addr AND op_ic_card_no = com.param ->> '$.icCardNo' | 
|---|
|  |  |  | ORDER BY op_dt DESC | 
|---|
|  |  |  | LIMIT 1 | 
|---|
|  |  |  | ) IS NULL | 
|---|
|  |  |  | GROUP BY com.rtu_addr, com.param ->> '$.icCardNo' | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!--根据RTU地址和虚拟卡编号获取成功开阀的最后一条记录,获取未关阀记录使用--> | 
|---|
|  |  |  | <select id="getLastComId" resultType="java.lang.Long"> | 
|---|
|  |  |  | SELECT com_id AS comId | 
|---|
|  |  |  | FROM rm_command_history | 
|---|
|  |  |  | WHERE result = 1 | 
|---|
|  |  |  | AND ((protocol = 'p206V1' OR protocol = 'p206V2') | 
|---|
|  |  |  | AND (command_code = '92' OR command_code = '97' OR command_code = '99' OR command_code = 'A0' OR command_code = 'A1' OR command_code = 'A2')) | 
|---|
|  |  |  | AND rtu_addr = #{rtuAddr} AND param ->> '$.icCardNo' = #{vcNum} | 
|---|
|  |  |  | ORDER BY send_time DESC | 
|---|
|  |  |  | LIMIT 1 | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <select id="getUnclosedValves" resultType="com.dy.pipIrrGlobal.voRm.VoUnclosedValve"> | 
|---|
|  |  |  | SELECT | 
|---|
|  |  |  | inta.name AS intakeNum, | 
|---|
|  |  |  | 
|---|
|  |  |  | com.send_time AS sendTime, | 
|---|
|  |  |  |  | 
|---|
|  |  |  | (SELECT dt FROM rm_work_report_last | 
|---|
|  |  |  | WHERE rtu_addr = com.rtu_addr AND ic_card_no = com.param ->> '$.icCardNo' | 
|---|
|  |  |  | <!--AND dt > (SELECT op_dt FROM rm_open_close_valve_last WHERE rtu_addr = com.rtu_addr AND op_ic_card_no = com.param ->> '$.icCardNo' ORDER BY op_dt DESC LIMIT 1)--> | 
|---|
|  |  |  | AND dt > com.send_time | 
|---|
|  |  |  | ORDER BY dt DESC | 
|---|
|  |  |  | LIMIT 1) AS dt, | 
|---|
|  |  |  | WHERE rtu_addr = com.rtu_addr AND ic_card_no = com.param ->> '$.icCardNo' | 
|---|
|  |  |  | AND dt > com.send_time | 
|---|
|  |  |  | ORDER BY dt DESC | 
|---|
|  |  |  | LIMIT 1) AS dt, | 
|---|
|  |  |  |  | 
|---|
|  |  |  | (SELECT water_instant FROM rm_work_report_last | 
|---|
|  |  |  | WHERE rtu_addr = com.rtu_addr AND ic_card_no = com.param ->> '$.icCardNo' | 
|---|
|  |  |  | <!--AND dt > (SELECT op_dt FROM rm_open_close_valve_last WHERE rtu_addr = com.rtu_addr AND op_ic_card_no = com.param ->> '$.icCardNo' ORDER BY op_dt DESC LIMIT 1)--> | 
|---|
|  |  |  | AND dt > com.send_time | 
|---|
|  |  |  | ORDER BY dt DESC | 
|---|
|  |  |  | WHERE rtu_addr = com.rtu_addr AND ic_card_no = com.param ->> '$.icCardNo' | 
|---|
|  |  |  | AND dt > com.send_time | 
|---|
|  |  |  | ORDER BY dt DESC | 
|---|
|  |  |  | LIMIT 1) AS waterInstant | 
|---|
|  |  |  |  | 
|---|
|  |  |  | FROM rm_command_history com | 
|---|
|  |  |  | INNER JOIN pr_controller con ON com.rtu_addr = con.rtuAddr | 
|---|
|  |  |  | INNER JOIN pr_intake inta ON con.intakeId = inta.id | 
|---|
|  |  |  | LEFT JOIN JSON_TABLE( | 
|---|
|  |  |  | <!--                '[{"rtuAddr":"620201000030","isOnLine":true}]',--> | 
|---|
|  |  |  | <!--'[{"rtuAddr":"620201000030","isOnLine":true}]',--> | 
|---|
|  |  |  | #{onLineMap}, | 
|---|
|  |  |  | '$[*]' COLUMNS ( | 
|---|
|  |  |  | rtuAddr VARCHAR(20) PATH '$.rtuAddr', | 
|---|
|  |  |  | isOnLine BOOLEAN PATH '$.isOnLine' | 
|---|
|  |  |  | ) | 
|---|
|  |  |  | ) | 
|---|
|  |  |  | ) rtus ON com.rtu_addr = rtus.rtuAddr | 
|---|
|  |  |  | <where> | 
|---|
|  |  |  | AND com.operator = #{operator} | 
|---|
|  |  |  | AND ((com.protocol = 'p206V1' OR com.protocol = 'p206V2') AND (com.command_code = '92' OR com.command_code = '97' OR com.command_code = '99' OR com.command_code = 'A0' OR com.command_code = 'A1' OR com.command_code = 'A2')) | 
|---|
|  |  |  | AND   com.com_id in (${comIds}) | 
|---|
|  |  |  | AND ( | 
|---|
|  |  |  | SELECT op_dt FROM rm_open_close_valve_last | 
|---|
|  |  |  | WHERE rtu_addr = com.rtu_addr AND op_ic_card_no = com.param ->> '$.icCardNo' | 
|---|
|  |  |  | ORDER BY op_dt DESC | 
|---|
|  |  |  | LIMIT 1 | 
|---|
|  |  |  | ) IS NOT NULL | 
|---|
|  |  |  |  | 
|---|
|  |  |  | AND ( | 
|---|
|  |  |  | SELECT cl_dt FROM rm_open_close_valve_last | 
|---|
|  |  |  | WHERE rtu_addr = com.rtu_addr AND op_ic_card_no = com.param ->> '$.icCardNo' | 
|---|
|  |  |  | 
|---|
|  |  |  | ) | 
|---|
|  |  |  | ) rtus ON com.rtu_addr = rtus.rtuAddr | 
|---|
|  |  |  | WHERE (com.command_code = '92' OR com.command_code = 'A2' OR com.command_code = '97') | 
|---|
|  |  |  | AND con.intakeId = #{intakeId} | 
|---|
|  |  |  | AND NOT EXISTS( | 
|---|
|  |  |  | SELECT * | 
|---|
|  |  |  | FROM rm_command_history | 
|---|
|  |  |  | WHERE (result IS NULL OR result = 1) | 
|---|
|  |  |  | AND (command_code = '93' OR command_code = 'A3' OR command_code = '98') | 
|---|
|  |  |  | AND param ->> '$.orderNo' = com.param ->> '$.orderNo' | 
|---|
|  |  |  | ) | 
|---|
|  |  |  | ORDER BY com.send_time DESC | 
|---|
|  |  |  | LIMIT 0,1 | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!--根据取水口ID获取该取水口未关阀参数--> | 
|---|
|  |  |  | <select id="getUncloseParamByCd" resultType="com.dy.pipIrrGlobal.voRm.VoUnclosedParam"> | 
|---|
|  |  |  | SELECT com.rtu_addr               AS rtuAddr, | 
|---|
|  |  |  | com.param ->> '$.orderNo'  AS orderNo, | 
|---|
|  |  |  | com.param ->> '$.icCardNo' AS vcNum | 
|---|
|  |  |  | FROM rm_command_history com | 
|---|
|  |  |  | INNER JOIN pr_controller con ON com.rtu_addr = con.rtuAddr | 
|---|
|  |  |  | INNER JOIN pr_intake inta ON con.intakeId = inta.id | 
|---|
|  |  |  | INNER JOIN JSON_TABLE( | 
|---|
|  |  |  | <!--      '[{"rtuAddr":"620201000029","isOnLine":true},{"rtuAddr":"4000004","isOnLine":true},{"rtuAddr":"dy20240325","isOnLine":false}]',--> | 
|---|
|  |  |  | #{onLineMap}, | 
|---|
|  |  |  | '$[*]' COLUMNS ( | 
|---|
|  |  |  | rtuAddr VARCHAR(20) PATH '$.rtuAddr', | 
|---|
|  |  |  | isOnLine BOOLEAN PATH '$.isOnLine' | 
|---|
|  |  |  | ) | 
|---|
|  |  |  | ) rtus ON com.rtu_addr = rtus.rtuAddr | 
|---|
|  |  |  | WHERE com.command_code = #{code} | 
|---|
|  |  |  | AND con.intakeId = #{intakeId} | 
|---|
|  |  |  | AND NOT EXISTS( | 
|---|
|  |  |  | SELECT * | 
|---|
|  |  |  | 
|---|
|  |  |  | FROM rm_command_history | 
|---|
|  |  |  | WHERE com_id = #{commId} | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!--根据命令日志ID获取开阀信息,终止灌溉计划时使用,用来执行远程关阀--> | 
|---|
|  |  |  | <select id="getValveOpen" resultType="com.dy.pipIrrGlobal.voRm.VoIntakeVc"> | 
|---|
|  |  |  | SELECT | 
|---|
|  |  |  | rtu_addr AS rtuAddr, | 
|---|
|  |  |  | param ->> '$.icCardNo' AS vcNum, | 
|---|
|  |  |  | param ->> '$.orderNo' AS orderNo | 
|---|
|  |  |  | FROM rm_command_history | 
|---|
|  |  |  | WHERE com_id = #{commandId} | 
|---|
|  |  |  | LIMIT 0, 1 | 
|---|
|  |  |  | </select> | 
|---|
|  |  |  | </mapper> | 
|---|