首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >每维顶N项的计算

每维顶N项的计算
EN

Stack Overflow用户
提问于 2021-10-22 15:08:25
回答 1查看 41关注 0票数 0

我有下面的查询,它显示每个产品每小时的总销售额。然而,这是非常大的数据,我不想看到所有的产品,所以我想看到的1000 product_id基于sales为每个datehourcategory_id维度。

代码语言:javascript
复制
SELECT date,
         hour,
         category_id,
         product_id,
         sum(sales) AS sales
FROM  a
LEFT JOIN 
    ON a.product_id = b.product_id
WHERE date(date) >= date('2021-01-01')
GROUP BY  1, 2, 3, 4

在雅典娜怎么做?

提前谢谢。

EN

回答 1

Stack Overflow用户

发布于 2021-10-22 15:34:56

您可以对结果使用rank函数,然后筛选出相应的级别:

代码语言:javascript
复制
SELECT date,
         hour,
         category_id,
         product_id,
         sales
FROM
(
    SELECT *,          
        rank() OVER (PARTITION BY date, hour, category_id
                    ORDER BY sales DESC) AS rnk
    FROM (your query)
)
WHERE rnk <= 1000
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69679213

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档