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

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

Linda Hamilton
发布: 2025-01-03 22:26:40
原创
466 人浏览过

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中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板