簡體   English   中英

使用 SQL 從排序組中獲取前 N 個

[英]Get top N from sorted group with SQL

假設我有這種格式的表格:

在此處輸入圖像描述

我想從每個頻道中獲得前 2 名,但頻道順序是按音量總和排序的 預期結果是:

在此處輸入圖像描述

通道 B 的總和為 5150,大於通道 A 與 3500 的總和。

我看到了用戶 ROW_NUMBER() 的一些問題,但它只能從每個類別中獲得前 N 個,而類別中沒有順序。 我該如何解決這個問題?

您可以在 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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM