From 7f66dd2dee66a81df6ab999fc9daea3ac60a3642 Mon Sep 17 00:00:00 2001
From: liurunyu <lry9898@163.com>
Date: 星期一, 20 一月 2025 13:52:44 +0800
Subject: [PATCH] 优化代码

---
 pipIrr-platform/pipIrr-global/src/main/resources/mapper/PrDivideMapper.xml |   67 ++++++++++++++++++++++++++-------
 1 files changed, 52 insertions(+), 15 deletions(-)

diff --git a/pipIrr-platform/pipIrr-global/src/main/resources/mapper/PrDivideMapper.xml b/pipIrr-platform/pipIrr-global/src/main/resources/mapper/PrDivideMapper.xml
index d9b4ac4..1348a36 100644
--- a/pipIrr-platform/pipIrr-global/src/main/resources/mapper/PrDivideMapper.xml
+++ b/pipIrr-platform/pipIrr-global/src/main/resources/mapper/PrDivideMapper.xml
@@ -227,8 +227,9 @@
       lat = #{lat,jdbcType=DOUBLE},
       remarks = #{remarks,jdbcType=VARCHAR},
       `operator` = #{operator,jdbcType=BIGINT},
-      operateDt = #{operatedt,jdbcType=TIMESTAMP},
-      deleted = #{deleted,jdbcType=TINYINT}
+      operateDt = #{operatedt,jdbcType=TIMESTAMP}
+<!--    ,-->
+<!--      deleted = #{deleted,jdbcType=TINYINT}-->
     where id = #{id,jdbcType=BIGINT}
   </update>
 
@@ -238,17 +239,18 @@
         COUNT(*) AS recordCount
     FROM pr_divide divi
         INNER JOIN ba_block blo ON divi.blockId = blo.id
-        INNER JOIN ba_district country ON divi.countyId = country.id
-        INNER JOIN ba_district town ON divi.townId = town.id
-        INNER JOIN ba_district village ON divi.villageid = village.id
+        Left JOIN ba_district country ON divi.countyId = country.id
+        Left JOIN ba_district town ON divi.townId = town.id
+        Left JOIN ba_district village ON divi.villageid = village.id
         , (SELECT @i:=0) AS itable
     <where>
+       divi. deleted = 0
       <if test = "divideName != null and divideName !=''">
         AND divi.name LIKE CONCAT('%',#{divideName},'%')
       </if>
 
-      <if test = "blockName != null and blockName !=''">
-        AND blo.name = #{blockName}
+      <if test = "blockId != null and blockId !=''">
+        AND divi.blockId = #{blockId}
       </if>
     </where>
   </select>
@@ -257,31 +259,66 @@
   <select id="getDivides" resultType="com.dy.pipIrrGlobal.voPr.VoDivide">
     SELECT
       (@i:=@i+1) AS id,
+      CAST(divi.id AS char) AS divideId,
       divi.name AS divideName,
+      CAST(divi.blockId AS char) AS blockId,
       blo.`name` AS blockName,
       divi.header,
+      divi.villages,
+      divi.area,
+      divi.lng,
+      divi.lat,
       divi.phone,
+      divi.remarks,
       CONCAT(country.`name`, town.`name`, village.`name`) AS address,
+      CAST(divi.operator AS char) AS operator,
       divi.operateDt
     FROM pr_divide divi
         INNER JOIN ba_block blo ON divi.blockId = blo.id
-        INNER JOIN ba_district country ON divi.countyId = country.id
-        INNER JOIN ba_district town ON divi.townId = town.id
-        INNER JOIN ba_district village ON divi.villageid = village.id
+        Left JOIN ba_district country ON divi.countyId = country.id
+        Left JOIN ba_district town ON divi.townId = town.id
+        Left JOIN ba_district village ON divi.villageid = village.id
         , (SELECT @i:=0) AS itable
     <where>
+       divi. deleted = 0
       <if test = "divideName != null and divideName !=''">
         AND divi.name LIKE CONCAT('%',#{divideName},'%')
       </if>
 
-      <if test = "blockName != null and blockName !=''">
-        AND blo.name = #{blockName}
+      <if test = "blockId != null and blockId !=''">
+        AND divi.blockId = #{blockId}
       </if>
     </where>
     ORDER BY divi.operateDt DESC
-    <if test="pageCurr != null and pageSize != null">
-      LIMIT ${pageCurr}, ${pageSize}
-    </if>
+    <trim prefix="limit " >
+      <if test="start != null and count != null">
+        #{start,javaType=Integer,jdbcType=INTEGER}, #{count,javaType=Integer,jdbcType=INTEGER}
+      </if>
+    </trim>
+  </select>
+
+  <!--鏍规嵁鍒嗘按鎴縄D閫昏緫鍒犻櫎鍒嗘按鎴�-->
+  <update id="deleteDivideById" parameterType="java.lang.Long">
+    update pr_divide set deleted = 1
+    <where>
+      <if test = "id != null and id > 0">
+        AND id = #{id}
+      </if>
+    </where>
+  </update>
+
+  <!--鏍规嵁鍒嗘按鎴跨紪鍙疯幏鍙栨墍灞炵墖鍖虹紪鍙�-->
+  <select id="getBlockIdById" resultType="java.lang.Long">
+    SELECT blockId FROM pr_divide WHERE id = #{divideId}
+  </select>
+
+  <!--鏍规嵁鐗囧尯ID鑾峰彇鍒嗘按鎴垮垪琛�-->
+  <select id="getDividesByBlockId" resultType="com.dy.pipIrrGlobal.voPr.VoSimpleDivide">
+    SELECT
+      id As value,
+      name AS label
+    FROM pr_divide
+    WHERE deleted = 0 AND blockId = #{blockId}
   </select>
 
 </mapper>
\ No newline at end of file

--
Gitblit v1.8.0