我想知道如何写这个查询。
我知道这个实际的语法是虚假的,但它将帮助您理解我想要的东西。
我需要这种格式,因为它是一个更大查询的一部分。
SELECT distributor_id,
COUNT(*) AS TOTAL,
COUNT(*) WHERE level = 'exec',
COUNT(*) WHERE level = 'personal'
我需要在一个查询中返回这一切。
此外,它需要在一行中,所以下面的将不起作用:
'SELECT distributor_id, COUNT(*)
GROUP BY distributor_id'
好吧,如果你必须在一个查询中所有这些,你可以做一个联合:
SELECT distributor_id, COUNT() FROM ... UNION
SELECT COUNT() AS EXEC_COUNT FROM ... WHERE level = 'exec' UNION
SELECT COUNT(*) AS PERSONAL_COUNT FROM ... WHERE level = 'personal';
或者,如果处理后可以做:
SELECT distributor_id, COUNT(*) FROM ... GROUP BY level;
您将得到每个级别的计数,并需要将它们全部加起来以得到总数。
好吧,如果你必须在一个查询中所有这些,你可以做一个联合:
SELECT distributor_id, COUNT() FROM ... UNION
SELECT COUNT() AS EXEC_COUNT FROM ... WHERE level = 'exec' UNION
SELECT COUNT(*) AS PERSONAL_COUNT FROM ... WHERE level = 'personal';
或者,如果处理后可以做:
SELECT distributor_id, COUNT(*) FROM ... GROUP BY level;
您将得到每个级别的计数,并需要将它们全部加起来以得到总数。
基于Taryn的回应,使用OVER()增加了细微差别:
SELECT distributor_id,
COUNT(*) total,
SUM(case when level = 'exec' then 1 else 0 end) OVER() ExecCount,
SUM(case when level = 'personal' then 1 else 0 end) OVER () PersonalCount
FROM yourtable
GROUP BY distributor_id
使用OVER()而不使用()将为您提供整个数据集的总计数。