[英]Get top N from sorted group with SQL
您可以在 ORDER BY 子句中将 ROW_NUMBER() 与 SUM 分析函数一起使用 -
SELECT channel, category, volume
FROM (SELECT ROW_NUMBER() OVER(PARTITION BY channel ORDER BY volume DESC) RN,
SUM(volume) OVER(PARTITION BY channel) tot_volume
channel, category, volume
FROM (SELECT channel, category, SUM(volume) volume
FROM your_table
GROUP BY channel, category
) t
) tmp
WHERE RN <= 2
ORDER BY tot_volume DESC, volume DESC;
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.