집 >데이터 베이스 >MySQL 튜토리얼 >파티션을 사용하여 SQL Server에서 고유 값의 누계를 효율적으로 계산하려면 어떻게 해야 합니까?
파티션 및 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!