mirror of
https://gitee.com/hhyykk/ipms-sjy.git
synced 2025-08-17 19:51:53 +08:00
91 lines
3.9 KiB
XML
91 lines
3.9 KiB
XML
<?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="cn.iocoder.yudao.module.crm.dal.mysql.statistics.CrmStatisticsPortraitMapper">
|
|
|
|
<select id="selectCustomerIndustryListGroupbyIndustryId"
|
|
resultType="cn.iocoder.yudao.module.crm.controller.admin.statistics.vo.portrait.CrmStatisticCustomerIndustryRespVO">
|
|
SELECT
|
|
industry_id,
|
|
COUNT(*) AS customerCount,
|
|
SUM(deal_status) AS dealCount,
|
|
ROUND(COUNT(*) / (SELECT COUNT(*) FROM crm_customer WHERE deleted = 0) * 100, 2) AS industryPortion,
|
|
ROUND(SUM(deal_status) / NULLIF(COUNT(*), 0) * 100, 2) AS dealPortion
|
|
FROM
|
|
crm_customer
|
|
WHERE
|
|
deleted = 0 AND industry_id IS NOT NULL
|
|
AND owner_user_id IN
|
|
<foreach collection="userIds" item="userId" open="(" close=")" separator=",">
|
|
#{userId}
|
|
</foreach>
|
|
AND create_time BETWEEN #{times[0],javaType=java.time.LocalDateTime} AND
|
|
#{times[1],javaType=java.time.LocalDateTime}
|
|
GROUP BY
|
|
industry_id;
|
|
</select>
|
|
<select id="selectCustomerSourceListGroupbySource"
|
|
resultType="cn.iocoder.yudao.module.crm.controller.admin.statistics.vo.portrait.CrmStatisticCustomerSourceRespVO">
|
|
SELECT
|
|
source,
|
|
COUNT(*) AS customerCount,
|
|
SUM(deal_status) AS dealCount,
|
|
ROUND(COUNT(*) / (SELECT COUNT(*) FROM crm_customer WHERE deleted = 0) * 100, 2) AS sourcePortion,
|
|
ROUND(SUM(deal_status) / NULLIF(COUNT(*), 0) * 100, 2) AS dealPortion
|
|
FROM
|
|
crm_customer
|
|
WHERE
|
|
deleted = 0 AND source IS NOT NULL
|
|
AND owner_user_id IN
|
|
<foreach collection="userIds" item="userId" open="(" close=")" separator=",">
|
|
#{userId}
|
|
</foreach>
|
|
AND create_time BETWEEN #{times[0],javaType=java.time.LocalDateTime} AND
|
|
#{times[1],javaType=java.time.LocalDateTime}
|
|
GROUP BY
|
|
source;
|
|
</select>
|
|
<select id="selectCustomerLevelListGroupbyLevel"
|
|
resultType="cn.iocoder.yudao.module.crm.controller.admin.statistics.vo.portrait.CrmStatisticCustomerLevelRespVO">
|
|
SELECT
|
|
level,
|
|
COUNT(*) AS customerCount,
|
|
SUM(deal_status) AS dealCount,
|
|
ROUND(COUNT(*) / (SELECT COUNT(*) FROM crm_customer WHERE deleted = 0) * 100, 2) AS levelPortion,
|
|
ROUND(SUM(deal_status) / NULLIF(COUNT(*), 0) * 100, 2) AS dealPortion
|
|
FROM
|
|
crm_customer
|
|
WHERE
|
|
deleted = 0 AND level IS NOT NULL
|
|
AND owner_user_id IN
|
|
<foreach collection="userIds" item="userId" open="(" close=")" separator=",">
|
|
#{userId}
|
|
</foreach>
|
|
AND create_time BETWEEN #{times[0],javaType=java.time.LocalDateTime} AND
|
|
#{times[1],javaType=java.time.LocalDateTime}
|
|
GROUP BY
|
|
level;
|
|
</select>
|
|
<select id="selectSummaryListByAreaId"
|
|
resultType="cn.iocoder.yudao.module.crm.controller.admin.statistics.vo.portrait.CrmStatisticCustomerAreaRespVO">
|
|
SELECT
|
|
area_id,
|
|
COUNT(*) AS customerCount,
|
|
SUM(deal_status) AS dealCount,
|
|
ROUND(COUNT(*) / (SELECT COUNT(*) FROM crm_customer WHERE deleted = 0) * 100, 2) AS areaPortion,
|
|
ROUND(SUM(deal_status) / NULLIF(COUNT(*), 0) * 100, 2) AS dealPortion
|
|
FROM
|
|
crm_customer
|
|
WHERE
|
|
deleted = 0 AND area_id IS NOT NULL
|
|
AND owner_user_id IN
|
|
<foreach collection="userIds" item="userId" open="(" close=")" separator=",">
|
|
#{userId}
|
|
</foreach>
|
|
AND create_time BETWEEN #{times[0],javaType=java.time.LocalDateTime} AND
|
|
#{times[1],javaType=java.time.LocalDateTime}
|
|
GROUP BY
|
|
area_id;
|
|
</select>
|
|
|
|
</mapper>
|