From 52123c927f77f41f71461ef0d422525656bd7b6f Mon Sep 17 00:00:00 2001
From: huminmin <mac@MacBook-Pro.local>
Date: 星期四, 07 五月 2026 11:53:26 +0800
Subject: [PATCH] 优化营销客户相关

---
 src/main/resources/mapper/basic/CustomerMapper.xml |   93 ++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 85 insertions(+), 8 deletions(-)

diff --git a/src/main/resources/mapper/basic/CustomerMapper.xml b/src/main/resources/mapper/basic/CustomerMapper.xml
index c0bc2fa..57dea6c 100644
--- a/src/main/resources/mapper/basic/CustomerMapper.xml
+++ b/src/main/resources/mapper/basic/CustomerMapper.xml
@@ -6,17 +6,23 @@
     <resultMap id="BaseResultMap" type="com.ruoyi.basic.pojo.Customer">
         <id column="id" property="id" />
     </resultMap>
-    <select id="listPage" resultType="com.ruoyi.basic.dto.CustomerDto">
+    <select id="listPage" resultType="com.ruoyi.basic.vo.CustomerVo">
         select
         c.*,
         u.user_name usage_user_name,
         (
         select group_concat(u2.user_name separator ', ')
-        from customer_private_pool cpp2
-        left join sys_user u2 on cpp2.bound_id = u2.user_id
-        where cpp2.customer_id = c.id
-        and cpp2.bound_id != c.usage_user
-        ) as together_user_names
+        from customer_user cu
+        left join sys_user u2 on cu.user_id = u2.user_id
+        where cu.customer_id = c.id
+        and cu.user_id != c.usage_user
+        ) as together_user_names,
+        (
+        select group_concat(cu.user_id separator ',')
+        from customer_user cu
+        where cu.customer_id = c.id
+        and cu.user_id != c.usage_user
+        ) as user_ids_str
         from customer c
         left join sys_user u on c.usage_user = u.user_id
         <where>
@@ -26,8 +32,79 @@
             <if test="c.customerType != null and c.customerType != ''">
                 and customer_type = #{c.customerType}
             </if>
+            <!-- 鍏捣鏌ヨ锛歵ype = 1锛堝叕娴峰鎴凤級-->
+            <if test="c.type != null and c.type == 1">
+                and type = #{c.type}
+            </if>
+            <!-- 绉佹捣鏌ヨ锛歵ype = 0锛堢娴峰鎴凤級鎴栬�� type = 1锛堝叕娴峰鎴凤級涓斿凡琚垎閰嶏紝骞朵笖鏄嚜宸遍鐢ㄣ�佽嚜宸卞垱寤烘垨鑰呭叡浜粰鑷繁鐨勫鎴� -->
+            <if test="c.type != null and c.type == 0">
+                and (
+                    (type = #{c.type} or (type = 1 and is_assigned = 1))
+                    and (
+                        c.usage_user = #{loginUserId}
+                        or c.create_user = #{loginUserId}
+                        or exists (
+                            select 1 from customer_user cu
+                            where cu.customer_id = c.id
+                            and cu.user_id = #{loginUserId}
+                        )
+                    )
+                )
+            </if>
         </where>
     </select>
 
-
-</mapper>
+    <select id="list" resultType="com.ruoyi.basic.vo.CustomerVo">
+        select
+        c.*,
+        u.user_name usage_user_name,
+        (
+        select group_concat(u2.user_name separator ', ')
+        from customer_user cu
+        left join sys_user u2 on cu.user_id = u2.user_id
+        where cu.customer_id = c.id
+        and cu.user_id != c.usage_user
+        ) as together_user_names,
+        (
+        select group_concat(cu.user_id separator ',')
+        from customer_user cu
+        where cu.customer_id = c.id
+        and cu.user_id != c.usage_user
+        ) as user_ids_str
+        from customer c
+        left join sys_user u on c.usage_user = u.user_id
+        <where>
+            <if test="c.ids != null and c.ids.length > 0">
+                and c.id in
+                <foreach collection="c.ids" item="id" open="(" separator="," close=")">
+                    #{id}
+                </foreach>
+            </if>
+            <if test="c.customerName != null and c.customerName != ''">
+                and customer_name like concat('%', #{c.customerName}, '%')
+            </if>
+            <if test="c.customerType != null and c.customerType != ''">
+                and customer_type = #{c.customerType}
+            </if>
+            <!-- 鍏捣鏌ヨ锛歵ype = 1锛堝叕娴峰鎴凤級-->
+            <if test="c.type != null and c.type == 1">
+                and type = #{c.type}
+            </if>
+            <!-- 绉佹捣鏌ヨ锛歵ype = 0锛堢娴峰鎴凤級鎴栬�� type = 1锛堝叕娴峰鎴凤級涓斿凡琚垎閰嶏紝骞朵笖鏄嚜宸遍鐢ㄣ�佽嚜宸卞垱寤烘垨鑰呭叡浜粰鑷繁鐨勫鎴� -->
+            <if test="c.type != null and c.type == 0">
+                and (
+                    (type = #{c.type} or (type = 1 and is_assigned = 1))
+                    and (
+                        c.usage_user = #{loginUserId}
+                        or c.create_user = #{loginUserId}
+                        or exists (
+                            select 1 from customer_user cu
+                            where cu.customer_id = c.id
+                            and cu.user_id = #{loginUserId}
+                        )
+                    )
+                )
+            </if>
+        </where>
+    </select>
+</mapper>
\ No newline at end of file

--
Gitblit v1.9.3