From 6e9f2c5ade8802645fd4e0b718ae14d40066b4d5 Mon Sep 17 00:00:00 2001
From: linwe <872216996@qq.com>
Date: Fri, 15 Dec 2023 18:17:21 +0800
Subject: [PATCH] 管理后台优化

---
 src/main/java/org/springblade/modules/house/mapper/HouseMapper.xml |  145 ++++++++++++++++++------------------------------
 1 files changed, 54 insertions(+), 91 deletions(-)

diff --git a/src/main/java/org/springblade/modules/house/mapper/HouseMapper.xml b/src/main/java/org/springblade/modules/house/mapper/HouseMapper.xml
index 6c35a85..98c0d5d 100644
--- a/src/main/java/org/springblade/modules/house/mapper/HouseMapper.xml
+++ b/src/main/java/org/springblade/modules/house/mapper/HouseMapper.xml
@@ -206,41 +206,33 @@
 
 
     <select id="getHouseStatisticsOne" resultType="java.lang.Integer">
-        SELECT
+     SELECT
         count( 1 )
         FROM
-        jczz_house jh
-        WHERE
-        jh.is_deleted = 0
-        AND
-        EXISTS (
-        SELECT
+        (
+        SELECT DISTINCT
         jda.building_code
         FROM
-        jczz_doorplate_address jda
+        jczz_house jh
+        LEFT JOIN jczz_doorplate_address jda ON jda.address_code = jh.house_code
         WHERE
-        jh.house_code = jda.address_code
-        AND jda.nei_code = #{code}
-        AND jda.building_code IS NOT NULL
-
+        jda.nei_code = #{code}
+        AND jh.is_deleted = 0
         <if test="userId != null">
-            AND EXISTS (
-            SELECT
-            *
-            FROM
-            jczz_grid jg
-            LEFT JOIN jczz_gridman jgm ON jg.id = jgm.grid_id
-            LEFT JOIN jczz_grid_range jgr ON jgr.grid_id = jg.id
-            WHERE
-            jgm.user_id = #{userId}
-            AND jh.house_code = jgr.house_code
-            AND jg.is_deleted = 0
-            )
-        </if>
-
-        GROUP BY
-        jda.building_code
+        AND jda.address_code IN (
+        SELECT DISTINCT
+        jgr.house_code
+        FROM
+        jczz_grid jg
+        LEFT JOIN jczz_gridman jgm ON jg.id = jgm.grid_id
+        LEFT JOIN jczz_grid_range jgr ON jgr.grid_id = jg.id
+        WHERE
+        jgm.user_id = #{userId}
+        AND jg.is_deleted = 0
         )
+        </if>
+        ) a
+
     </select>
 
 
@@ -248,75 +240,55 @@
         SELECT
         count( 1 )
         FROM
-        jczz_house jh
-        WHERE
-        jh.is_deleted = 0
-        AND
-        EXISTS (
-        SELECT
+        (
+        SELECT DISTINCT
         jda.address_code
         FROM
-        jczz_doorplate_address jda
+        jczz_house jh
+        LEFT JOIN jczz_doorplate_address jda ON jda.address_code = jh.house_code
         WHERE
-        jh.house_code = jda.address_code
-        AND jda.nei_code = #{code}
-        AND jda.building_code IS NOT NULL
-
+        jda.nei_code = #{code}
+        AND jh.is_deleted = 0
         <if test="userId != null">
-            AND EXISTS (
-            SELECT
-            *
+            AND jda.address_code IN (
+            SELECT DISTINCT
+            jgr.house_code
             FROM
             jczz_grid jg
             LEFT JOIN jczz_gridman jgm ON jg.id = jgm.grid_id
             LEFT JOIN jczz_grid_range jgr ON jgr.grid_id = jg.id
             WHERE
             jgm.user_id = #{userId}
-            AND jh.house_code = jgr.house_code
             AND jg.is_deleted = 0
             )
         </if>
-
-        GROUP BY
-        jda.address_code
-        )
+        ) a
 
     </select>
 
 
     <select id="getHouseStatisticsThree" resultType="java.lang.Integer">
         SELECT
-        count(1)
+        count( 1 )
         FROM
         jczz_household jhh
-        LEFT JOIN jczz_house jh ON jhh.house_code = jh.house_code
+        LEFT JOIN jczz_doorplate_address jda ON jda.address_code = jhh.house_code
         WHERE
-        jh.is_deleted = 0
+        jda.nei_code =  #{code}
         AND jhh.is_deleted = 0
-        AND jhh.house_code IN (
-        SELECT
-        jda.address_code
-        FROM
-        jczz_doorplate_address jda
-        WHERE
-        jh.house_code = jda.address_code
-        AND jda.nei_code = #{code}
         <if test="userId != null">
-            AND EXISTS (
-            SELECT
-            *
-            FROM
-            jczz_grid jg
-            LEFT JOIN jczz_gridman jgm ON jg.id = jgm.grid_id
-            LEFT JOIN jczz_grid_range jgr ON jgr.grid_id = jg.id
-            WHERE
-            jgm.user_id = #{userId}
-            AND jh.house_code = jgr.house_code
-            AND jg.is_deleted = 0
-            )
-        </if>
+        AND jda.address_code IN (
+        SELECT
+        jgr.house_code
+        FROM
+        jczz_grid jg
+        LEFT JOIN jczz_gridman jgm ON jg.id = jgm.grid_id
+        LEFT JOIN jczz_grid_range jgr ON jgr.grid_id = jg.id
+        WHERE
+        jgm.user_id = #{userId}
+        AND jg.is_deleted = 0
         )
-
+        </if>
     </select>
 
 
@@ -324,38 +296,29 @@
         SELECT
         count( 1 )
         FROM
-        jczz_house jh
-        WHERE
-        jh.is_deleted = 0
-        AND
-        EXISTS (
-        SELECT
+        (
+        SELECT DISTINCT
         jda.unit_code
         FROM
-        jczz_doorplate_address jda
+        jczz_house jh
+        LEFT JOIN jczz_doorplate_address jda ON jda.address_code = jh.house_code
         WHERE
-        jh.house_code = jda.address_code
-        AND jda.nei_code = #{code}
-        AND jda.building_code IS NOT NULL
-
+        jda.nei_code = #{code}
+        AND jh.is_deleted = 0
         <if test="userId != null">
-            AND EXISTS (
-            SELECT
-            *
+            AND jda.address_code IN (
+            SELECT DISTINCT
+            jgr.house_code
             FROM
             jczz_grid jg
             LEFT JOIN jczz_gridman jgm ON jg.id = jgm.grid_id
             LEFT JOIN jczz_grid_range jgr ON jgr.grid_id = jg.id
             WHERE
             jgm.user_id = #{userId}
-            AND jh.house_code = jgr.house_code
             AND jg.is_deleted = 0
             )
         </if>
-
-        GROUP BY
-        jda.unit_code
-        )
+        ) a
 
 
     </select>

--
Gitblit v1.9.3