>데이터 베이스 >MySQL 튜토리얼 >SQL 테이블에서 연속 값 발생을 효율적으로 계산하는 방법은 무엇입니까?

SQL 테이블에서 연속 값 발생을 효율적으로 계산하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-05 06:43:42241검색

How to Efficiently Count Consecutive Value Occurrences in a SQL Table?

테이블에서 값의 연속 발생 횟수 계산

값 열이 포함된 테이블이 있는 데이터베이스에서 연속 발생 횟수 확인 각 값을 선택하는 것은 다양한 데이터 분석 시나리오에 유용한 작업이 될 수 있습니다. 이 질문은 효율적인 SQL 기술을 사용하여 이 개수를 달성하는 과제를 탐구합니다.

제공된 데이터는 'A', 'B' 및 'C' 값을 포함하는 Id 열과 Name 열이 있는 테이블로 구성됩니다. 목표는 이름 열에서 이러한 값이 연속으로 나타나는 횟수를 계산하고 결과를 다음과 같이 표시하는 것입니다.

+------+------------+
| Name | Repetition |
+------+------------+
| A    |          2 |
| B    |          4 |
| C    |          1 |
| B    |          2 |
+------+------------+

시도한 접근 방식 중 하나는 이름별로 파티션에 대해 COUNT() 함수를 사용하는 것이었지만 이로 인해 결과가 나왔습니다. 잘못된 결과. 이 문제를 해결하기 위해 행 번호를 활용하는 대체 방법을 사용할 수 있습니다.

다음 코드 조각은 향상된 솔루션을 제시합니다.

select name, count(*)
from (
    select t.*,
           (
               row_number() over (order by id) -
               row_number() over (partition by name order by id)
           ) as grp
    from t
) t
group by grp, name;

이 접근 방식은 두 행 번호의 차이를 활용하여 연속된 행 번호를 식별합니다. 발생. 전체 행 번호에서 각 그룹 내의 행 번호를 빼면 각 연속 값 시퀀스에 대해 고유한 그룹 식별자가 생성됩니다. 그런 다음 COUNT() 함수가 이러한 그룹에 적용되어 연속되는 각 값에 대해 원하는 개수를 제공합니다.

위 내용은 SQL 테이블에서 연속 값 발생을 효율적으로 계산하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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