<?xml version="1.0" encoding="UTF-8"?>
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
<mapper namespace="com.ruoyi.basic.mapper.CustomerMapper">
|
|
<!-- 通用查询映射结果 -->
|
<resultMap id="BaseResultMap" type="com.ruoyi.basic.pojo.Customer">
|
<id column="id" property="id" />
|
</resultMap>
|
<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_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.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>
|
<!-- 公海查询:type = 1(公海客户)-->
|
<if test="c.type != null and c.type == 1">
|
and type = #{c.type}
|
</if>
|
<!-- 私海查询:type = 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>
|
|
<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>
|
<!-- 公海查询:type = 1(公海客户)-->
|
<if test="c.type != null and c.type == 1">
|
and type = #{c.type}
|
</if>
|
<!-- 私海查询:type = 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>
|