我有一个公司的列表,他们的行业和他们的年收入。
我需要按行业划分该榜单,并计算出每个行业需要多少家公司才能占该行业总收入的80%。
我可以运行分区,我可以计算出每个行业80%的收入,但我完全不知道如何计算出需要多少家公司才能达到80%。我唯一的想法是为每个行业列出一个列表,从高到低对收入进行排序,然后向下求和,直到我达到80%的数字。
这里有没有什么内置的函数或者聪明的方法可以帮到我?
谢谢!
发布于 2019-02-06 01:33:36
我会使用窗口函数:
select industry, count(*)
from (select t.*,
sum(revenue) over (partition by industry order by revenue desc) as running_revenue,
sum(revenue) over (partition by industry) as total_revenue
from t
) t
where running_revenue - revenue < 0.8 * total_revenue
group by industry;
where
指数涵盖了第一家超过80%门槛的公司。
还可以使用其他函数,如ntile()
和percentile()
。我发现直接使用sum()
进行计算是最简单的。
https://stackoverflow.com/questions/54540014
复制相似问题