首页 >数据库 >mysql教程 >如何使用分区有效计算 SQL Server 中不同值的运行总计?

如何使用分区有效计算 SQL Server 中不同值的运行总计?

Linda Hamilton
Linda Hamilton原创
2025-01-03 22:26:40481浏览

How Can I Efficiently Calculate a Running Total of Distinct Values in SQL Server Using Partitions?

使用分区和 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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn