Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/sql-server-2008/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
SQL Server 2008中(分区依据)上的计数(不同([value])_Sql_Sql Server 2008_Window Functions - Fatal编程技术网

SQL Server 2008中(分区依据)上的计数(不同([value])

SQL Server 2008中(分区依据)上的计数(不同([value]),sql,sql-server-2008,window-functions,Sql,Sql Server 2008,Window Functions,我已经写了这篇文章,并在Oracle中成功执行 COUNT (DISTINCT APEC.COURSE_CODE) OVER ( PARTITION BY s.REGISTRATION_NUMBER ,APEC.APE_ID ,COV.

我已经写了这篇文章,并在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中不能对进行计数(distinct)。您可以通过子查询来完成。其思想是枚举每个课程代码中的值(并根据其他分区条件).然后,只需将序列号为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)
,并将当前查询作为最终查询的子查询或CTE。

以下是我最近遇到的问题。我从中得到了它。到目前为止,它对我来说非常有效

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

在dba站点上,这可能是GREAT的重复,谢谢!这包括
NULL
值,而
COUNT()
没有。