SELECT r.industry_1,r.industry_2,r.agent_id,r.agent_name,
COUNT(DISTINCT r.customer_name_a)数据总量,
COUNT(DISTINCT CASE WHEN r.ifhs='Y' THEN r.customer_name_a END)海关数据量,
COUNT(DISTINCT CASE WHEN r.ifgjh='Y'THEN r.customer_name_a END)广交会数据量,
COUNT(DISTINCT CASE WHEN r.zlly LIKE '%A级-%' THEN r.customer_name_a END)老客户数据量
FROM rep_com_allinfo r WHERE r.outbound='10000115'
GROUP BY r.industry_1,r.industry_2,r.agent_id,r.agent_name
备注:10000115表示2010美容项目组
而且最重要的是 此处用的count是聚合函数 所以一定要在最后用group by语句进行分组
详细解析:
在介绍GROUP BY 和 HAVING 子句前,我们必需先讲讲sql语言中一种特殊的函数:聚合函数,例如SUM, COUNT, MAX, AVG等。这些函数和其它函数的根本区别就是它们一般作用在多条记录上。
SELECT SUM(population) FROM bbc |
SELECT region, SUM(population), SUM(area) FROM bbc GROUP BY region |
SELECT region, SUM(population), SUM(area) FROM bbc GROUP BY region HAVING SUM(area)>1000000 |
=================================================================================
GROUP BY 是分组查询, 一般 GROUP BY 是和 聚合函数配合使用,你可以想想
你用了GROUP BY 按 ITEM.ITEMNUM 这个字段分组,那其他字段内容不同,变成一对多又改如何显示呢,比如下面所示
A B
1 abc
1 bcd
1 asdfg
select A,B from table group by A
你说这样查出来是什么结果,
A B
abc
1 bcd
asdfg
右边3条如何变成一条,所以需要用到聚合函数,比如
select A,count(B) 数量 from table group by A
这样的结果就是
A 数量
1 3
group by 有一个原则,就是 select 后面的所有列中,没有使用聚合函数的列,必须出现在 group by 后面 。
转自:http://fangchengmi123.blog.163.com/blog/static/106833456201022461420632/