首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL:按排名/按总排名筛选

SQL:按排名/按总排名筛选
EN

Stack Overflow用户
提问于 2016-12-27 17:43:59
回答 0查看 504关注 0票数 2

我有一个非常标准的"append only“表,使用Amazon Redshift将created_atgroup_name作为列。

我想按组生成过去时间范围的前N行的时间序列。

目前我使用的是:

代码语言:javascript
复制
SELECT
    date_trunc('day', created_at) AS timeseries,
    my_table.group_name,
    COUNT(*) AS count
FROM
    my_table
JOIN (
    SELECT
        group_name,
        ROW_NUMBER() OVER (ORDER BY COUNT(*) DESC) AS rank
    FROM
        my_table
    WHERE
        created_at > (CURRENT_DATE - INTERVAL '1 days')
    GROUP BY
        group_name
    ) ranking ON (ranking.group_name = my_table.group_name)
WHERE
    created_at > (CURRENT_DATE - INTERVAL '1 days')
GROUP BY
    timeseries,
    my_table.group_name,
    ranking.rank
HAVING 
    ranking.rank <= 5
ORDER BY
    timeseries DESC

这很容易出错,因为created_at范围的过滤出现了两次,如果需要更改就会引起问题。

有没有办法让这个查询更优雅(理想情况下只使用一次时间过滤器)?

EN

回答

页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41342713

复制
相关文章

相似问题

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