>데이터 베이스 >MySQL 튜토리얼 >파티션을 사용하여 SQL Server에서 고유 값의 누계를 효율적으로 계산하려면 어떻게 해야 합니까?

파티션을 사용하여 SQL Server에서 고유 값의 누계를 효율적으로 계산하려면 어떻게 해야 합니까?

Linda Hamilton
Linda Hamilton원래의
2025-01-03 22:26:40470검색

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 키워드가 파티션 함수 내에서 직접 지원되지 않습니다. 그러나density_rank()함수를 활용하면 비슷한 결과를 효과적으로 얻을 수 있다. 다음 수식은 고유 값에 대해 원하는 개수를 반환합니다.

dense_rank() over (partition by [Mth] order by [UserAccountKey]) 
+ dense_rank() over (partition by [Mth] order by [UserAccountKey] desc) 
- 1

이 수식은 매월 각 UserAccountKey의 밀집 순위를 오름차순 및 내림차순으로 계산한 후 1을 뺍니다. 결과는 해당 월의 고유 UserAccountKeys 수로, 원하는 누계를 제공합니다.

위 내용은 파티션을 사용하여 SQL Server에서 고유 값의 누계를 효율적으로 계산하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.