使用分区和 Dense_Rank() OVER 实现不同计数
尝试使用 COUNT() OVER 计算不同值的运行总计时,包含 DISTINCT 关键字通常会导致错误。虽然您可以采用相关子查询等传统方法,但存在更有效的解决方案。
在 SQL Server 中,分区函数不直接支持 DISTINCT 关键字。然而,通过使用dense_rank()函数,您可以有效地获得类似的结果。以下公式将返回所需的不同值的计数:
dense_rank() over (partition by [Mth] order by [UserAccountKey]) + dense_rank() over (partition by [Mth] order by [UserAccountKey] desc) - 1
此公式按升序和降序计算每个 UserAccountKey 在每个月内的密集排名,然后减去 1。结果正是该月内唯一 UserAccountKey 的数量,为您提供所需的运行总数。
以上是如何使用分区有效计算 SQL Server 中不同值的运行总计?的详细内容。更多信息请关注PHP中文网其他相关文章!