我有一个mysql表的格式,让我们称之为product_revenue Product_id,年,月,收入
我需要获取以下列: year、month、revenue_top_5_monthly
其中revenue_top_5_monthly是当月收入最高的产品的收入总和。每月排名前5位的产品各不相同。
我可以通过选择使用子查询单个月,按收入排序并使用limit 5,然后对值进行求和来对单个月执行此操作,但我不知道如何在单个查询中执行此操作
我所拥有的是
select 'y' as year, 'x' as month, sum(revenue) as revenue_top_5 from
(select revenue from product_revenue
where month=x and year=y
order by revenue desc
limit 5) as top5
但我每个月都需要它。
product_revenue表在16个月内有超过10m的行,因此最终的查询速度非常重要。对于一个月,目前大约需要80-100秒,我必须在1小时30分钟的时间内运行大约30个这样的查询,每个查询持续16个月。
正如建议的那样,我也尝试了
select * from
(
select dd.year, dd.monthnumber,
u.product_id, sum(revenue) as revenue
from source
group by 1,2,3
)a
where
(select count(*) from
(select dd.year, dd.monthnumber,
u.product_id, sum(revenue) as revenue
from source
group by 1,2,3)b
where b.year=a.year and b.monthnumber=a.monthnumber and b.revenue<=a.revenue
)<=5
但不返回任何行。各个子查询a和b返回预期的行,名为。
发布于 2013-05-15 17:13:40
试试这个和c。
select top 5 'y' as year,'x' as month,sum(total) as top_5 From
(select sum(revenue) as total from product_revenue
where month=x and year=y
order by revenue desc) as t
https://stackoverflow.com/questions/16560770
复制相似问题