[英]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.