簡體   English   中英

SQL Server 2008中的Count(Distinct([value))OVER(Partition by)

[英]Count (Distinct ([value)) OVER (Partition by) in SQL Server 2008

我寫了這個並在Oracle中成功執行

COUNT (DISTINCT APEC.COURSE_CODE) OVER (
                                            PARTITION BY s.REGISTRATION_NUMBER
                                            ,APEC.APE_ID
                                            ,COV.ACADEMIC_SESSION
                                            ) APE_COURSES_PER_ACADEMIC_YEAR

我正在嘗試在SQL Server中實現相同的結果(我們的源數據庫使用Oracle,但我們的倉庫使用SQL Server)。

我知道SQL Server 2008中的窗口函數不支持distinct - 有人可以提出替代方案嗎?

唉,你不能在SQL Server中count(distinct) over 您可以使用子查詢執行此操作。 我們的想法是枚舉每個課程代碼中的值(並遵循其他分區條件)。 然后,只計算序列號為1的值:

select sum(case when cc_seqnum = 1 then 1 else 0 end) as APE_COURSES_PER_ACADEMIC_YEAR
from (select . . . ,
             row_number () OVER (PARTITION BY s.REGISTRATION_NUMBER, APEC.APE_ID,
                                              COV.ACADEMIC_SESSION,
                                              APEC.COURSE_CODE
                                 ORDER BY (SELECT NULL)
                                ) as cc_seqnum
      from . . . 
     ) t

您有一個復雜的查詢。 我建議您使用row_number()替換count(distinct) ,並使當前查詢成為最終查詢的子查詢或CTE。

這是我最近遇到的。 我從這篇文章中得到了它。 到目前為止,它對我來說真的很好。

DENSE_RANK() OVER (PARTITION BY PartitionByFields ORDER BY OrderByFields ASC) +
DENSE_RANK() OVER (PARTITION BY PartitionByFields ORDER BY OrderByFields DESC) - 1 AS DistinctCount

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

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