From c66ed1dcf64032a45ba053cd9ae71317d29d1fe3 Mon Sep 17 00:00:00 2001
From: liurunyu <lry9898@163.com>
Date: 星期二, 21 一月 2025 14:18:11 +0800
Subject: [PATCH] 针对远程RTU升级,增加快速命令类型,为此增加相关配置,增加相关处理逻辑

---
 pipIrr-platform/pipIrr-global/src/main/resources/mapper/PrControllerMapper.xml |   81 +++++++++++++++++++---------------------
 1 files changed, 39 insertions(+), 42 deletions(-)

diff --git a/pipIrr-platform/pipIrr-global/src/main/resources/mapper/PrControllerMapper.xml b/pipIrr-platform/pipIrr-global/src/main/resources/mapper/PrControllerMapper.xml
index 9f98c8b..fe7b623 100644
--- a/pipIrr-platform/pipIrr-global/src/main/resources/mapper/PrControllerMapper.xml
+++ b/pipIrr-platform/pipIrr-global/src/main/resources/mapper/PrControllerMapper.xml
@@ -8,6 +8,7 @@
     <result column="intakeId" jdbcType="BIGINT" property="intakeId" />
     <result column="rtuAddr" jdbcType="VARCHAR" property="rtuAddr" />
     <result column="protocol" jdbcType="VARCHAR" property="protocol" />
+    <result column="protocol_version" jdbcType="INTEGER" property="protocolVersion" />
     <result column="findDt" jdbcType="TIMESTAMP" property="findDt" />
     <result column="orgTag" jdbcType="VARCHAR" property="orgTag" />
     <result column="addWays" jdbcType="TINYINT" property="addWays" />
@@ -23,7 +24,7 @@
 
   <sql id="Base_Column_List">
     <!--@mbg.generated-->
-    id, intakeId, rtuAddr, protocol, findDt, orgTag, addWays, `operator`, operateDt, deleted
+    id, intakeId, rtuAddr, protocol, protocol_version, findDt, orgTag, addWays, `operator`, operateDt, deleted
   </sql>
   <sql id="Part_Column_List">
     <!--@mbg.generated-->
@@ -44,11 +45,11 @@
   <insert id="insert" parameterType="com.dy.pipIrrGlobal.pojoPr.PrController">
     <!--@mbg.generated-->
     insert into pr_controller (id, intakeId, rtuAddr,
-      protocol, findDt, orgTag, addWays,
+      protocol, protocol_version, findDt, orgTag, addWays,
       `operator`, operateDt, deleted
       )
     values (#{id,jdbcType=BIGINT}, #{intakeId,jdbcType=BIGINT}, #{rtuAddr,jdbcType=VARCHAR},
-      #{protocol,jdbcType=VARCHAR}, #{findDt,jdbcType=TIMESTAMP}, #{orgTag,jdbcType=VARCHAR},
+      #{protocol,jdbcType=VARCHAR}, #{protocolVersion,jdbcType=INTEGER}, #{findDt,jdbcType=TIMESTAMP}, #{orgTag,jdbcType=VARCHAR},
       #{addWays,jdbcType=TINYINT}, #{operator,jdbcType=BIGINT}, #{operateDt,jdbcType=TIMESTAMP},
       #{deleted,jdbcType=TINYINT}
       )
@@ -68,6 +69,9 @@
       </if>
       <if test="protocol != null">
         protocol,
+      </if>
+     <if test="protocolVersion != null">
+       protocol_version,
       </if>
       <if test="findDt != null">
         findDt,
@@ -100,6 +104,9 @@
       </if>
       <if test="protocol != null">
         #{protocol,jdbcType=VARCHAR},
+      </if>
+      <if test="protocolVersion != null">
+        #{protocolVersion,jdbcType=INTEGER},
       </if>
       <if test="findDt != null">
         #{findDt,jdbcType=TIMESTAMP},
@@ -134,6 +141,9 @@
       <if test="protocol != null">
         protocol = #{protocol,jdbcType=VARCHAR},
       </if>
+     <if test="protocolVersion != null">
+        protocol_version = #{protocolVersion,jdbcType=INTEGER},
+      </if>
       <if test="findDt != null">
         findDt = #{findDt,jdbcType=TIMESTAMP},
       </if>
@@ -161,6 +171,7 @@
     set intakeId = #{intakeId,jdbcType=BIGINT},
       rtuAddr = #{rtuAddr,jdbcType=VARCHAR},
       protocol = #{protocol,jdbcType=VARCHAR},
+      protocol_version = #{protocolVersion,jdbcType=INTEGER},
       findDt = #{findDt,jdbcType=TIMESTAMP},
       orgTag = #{orgTag,jdbcType=VARCHAR},
       addWays = #{addWays,jdbcType=TINYINT},
@@ -172,7 +183,7 @@
 
   <!--鏍规嵁鎺у埗鍣ㄧ紪鍙峰垹闄ゅ彇姘村彛缂栧彿-->
   <update id="deleteIntakeId">
-    UPDATE pr_controller SET intakeId = null WHERE id = ${controllerId}
+    UPDATE pr_controller SET intakeId = null WHERE id = #{controllerId}
   </update>
 
   <!--鏍规嵁鎸囧畾鏉′欢鑾峰彇鎺у埗鍣ㄨ褰曟暟-->
@@ -180,32 +191,26 @@
     SELECT
         COUNT(*) AS recordCount
     FROM pr_controller con
-    LEFT JOIN pr_intake_controller ic ON ic.controllerId = con.id
     INNER JOIN pr_intake inta ON con.intakeId = inta.id
-    left JOIN JSON_TABLE(
-    <!--'[{"rtuAddr":"37142501020100215","isOnLine":true},{"rtuAddr":"4000004","isOnLine":true},{"rtuAddr":"dy20240325","isOnLine":false}]',-->
-        #{onLineMap},
-        '$[*]' COLUMNS(
-        rtuAddr VARCHAR(20) PATH '$.rtuAddr',
-        isOnLine BOOLEAN PATH '$.isOnLine'
-        )
-    ) rtus ON con.rtuAddr = rtus.rtuAddr
     <where>
       AND con.deleted = 0
 
       <if test = "id != null and id > 0">
-        AND con.id = ${id}
+        AND con.id = #{id}
       </if>
       <if test = "rtuAddr != null and rtuAddr !=''">
-        AND con.rtuAddr like CONCAT('%',#{rtuAddr},'%')
+        AND con.rtuAddr = #{rtuAddr}
       </if>
-      <if test="isOnLine != null and isOnLine !='' ">
-        AND rtus.isOnLine = #{isOnLine}
+      <if test = "intakeNum != null and intakeNum !=''">
+        AND inta.name like CONCAT('%',#{intakeNum},'%')
       </if>
-      <if test = "bindNumber != null and bindNumber > 0">
-        AND (SELECT COUNT(*) FROM pr_intake_controller WHERE controllerId = con.id AND intakeId = inta.id AND operateType = 1) = ${bindNumber}
+      <if test = "protocolName != null and protocolName !=''">
+        AND con.protocol = #{protocolName}
       </if>
-    </where>
+      <if test = "protocolVersion != null">
+        AND con.protocol_version = #{protocolVersion}
+      </if>
+     </where>
   </select>
 
   <!--鏍规嵁鎸囧畾鏉′欢鑾峰彇鎺у埗鍣ㄨ褰�-->
@@ -215,38 +220,30 @@
         con.rtuAddr AS rtuAddr,
         inta.name AS intakeName,
         con.protocol,
+        con.protocol_version,
         inta.remarks,
-        rtus.isOnLine,
-        (SELECT COUNT(*) FROM pr_intake_controller WHERE controllerId = con.id AND operateType = 1) AS bindNumber,
         con.findDt AS findDt
     FROM pr_controller con
-        LEFT JOIN pr_intake_controller ic ON ic.controllerId = con.id
         INNER JOIN pr_intake inta ON con.intakeId = inta.id
-        left JOIN JSON_TABLE(
-        <!--'[{"rtuAddr":"37142501020100215","isOnLine":true},{"rtuAddr":"4000004","isOnLine":true},{"rtuAddr":"dy20240325","isOnLine":false}]',-->
-             #{onLineMap},
-             '$[*]' COLUMNS(
-             rtuAddr VARCHAR(20) PATH '$.rtuAddr',
-             isOnLine BOOLEAN PATH '$.isOnLine'
-             )
-        ) rtus ON con.rtuAddr = rtus.rtuAddr
     <where>
       AND con.deleted = 0
-
       <if test = "id != null and id > 0">
-        AND con.id = ${id}
+        AND con.id = #{id}
       </if>
       <if test = "rtuAddr != null and rtuAddr !=''">
-        AND con.rtuAddr like CONCAT('%',#{rtuAddr},'%')
+        AND con.rtuAddr = #{rtuAddr}
       </if>
-      <if test="isOnLine != null and isOnLine !='' ">
-        AND rtus.isOnLine = #{isOnLine}
+      <if test = "intakeNum != null and intakeNum !=''">
+        AND inta.name like CONCAT('%',#{intakeNum},'%')
       </if>
-      <if test = "bindNumber != null and bindNumber > 0">
-        AND (SELECT COUNT(*) FROM pr_intake_controller WHERE controllerId = con.id AND operateType = 1) = ${bindNumber}
+      <if test = "protocolName != null and protocolName !=''">
+        AND con.protocol = #{protocolName}
+      </if>
+      <if test = "protocolVersion != null">
+        AND con.protocol_version = #{protocolVersion}
       </if>
     </where>
-    ORDER BY con.operateDt DESC
+    ORDER BY con.id DESC
     <trim prefix="limit " >
       <if test="start != null and count != null">
         #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER}
@@ -274,17 +271,17 @@
 
   <!--鏍规嵁鎺у埗鍣ㄧ紪鍙烽�昏緫鍒犻櫎鎺у埗-->
   <update id="deleteControllerById">
-    UPDATE pr_controller SET deleted = 1 WHERE id = ${controllerId}
+    UPDATE pr_controller SET deleted = 1 WHERE id = #{controllerId}
   </update>
 
   <!--鏍规嵁鎺у埗鍣ㄧ紪鍙疯幏鍙栨湭鍒犻櫎鐨勬帶鍒跺櫒鏁伴噺-->
   <select id="getRecordCountOfController" resultType="java.lang.Integer">
-    SELECT COUNT(*) AS recordCount FROM pr_controller WHERE deleted = 0 AND id = ${controllerId}
+    SELECT COUNT(*) AS recordCount FROM pr_controller WHERE deleted = 0 AND id = #{controllerId}
   </select>
 
   <!--鏍规嵁娴佹氮鎺у埗鍣ㄧ紪鍙疯幏鍙栧凡缁戝畾璁板綍鏁�-->
   <select id="getBindedCount" resultType="java.lang.Integer">
-    SELECT COUNT(*) AS recordCount FROM pr_controller WHERE rtuAddr = (SELECT rtuAddr FROM pr_controller_tramp WHERE id = ${controllerId}) AND intakeId IS NOT NULL
+    SELECT COUNT(*) AS recordCount FROM pr_controller WHERE rtuAddr = (SELECT rtuAddr FROM pr_controller_tramp WHERE id = #{controllerId}) AND intakeId IS NOT NULL
   </select>
 
   <!--鏍规嵁鍙栨按鍙D鎴栭榾鎺у櫒鍦板潃鑾峰彇闃�鎺у櫒瀵硅薄-->

--
Gitblit v1.8.0