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

时间:2014-12-19 12:49:39

标签: sql sql-server-2008 window-functions

我写过这篇文章并在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 - 有人可以提出替代方案吗?

2 个答案:

答案 0 :(得分:9)

唉,你不能在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

您有一个复杂的查询。我建议您将count(distinct)替换为row_number(),并将当前查询作为最终查询的子查询或CTE。

答案 1 :(得分:7)

这是我最近遇到的情况。我是从post获得的。到目前为止,它对我来说真的很好。

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