>데이터 베이스 >MySQL 튜토리얼 >데이터베이스 열에서 연속 값 발생을 계산하는 방법은 무엇입니까?

데이터베이스 열에서 연속 값 발생을 계산하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2025-01-05 15:16:43757검색

How to Count Consecutive Value Occurrences in a Database Column?

테이블 열의 연속 발생 횟수를 계산하는 방법

테이블의 데이터로 작업할 때 연속 발생 횟수를 계산하는 것이 유용할 수 있습니다. 특정 열에서 값이 연속적으로 발생하는 횟수입니다. 예를 들어, 테이블에 직원 이름을 나타내는 열이 포함되어 있는 경우 동일한 직원 이름이 행에 나타나는 횟수를 알고 싶을 수 있습니다.

문제

다음 표를 고려하세요.

create table #t (Id int, Name char)

insert into #t values
(1, 'A'),
(2, 'A'),
(3, 'B'),
(4, 'B'),
(5, 'B'),
(6, 'B'),
(7, 'C'),
(8, 'B'),
(9, 'B')

목표는 "이름"에서 각 값이 연속으로 나타나는 횟수를 계산하는 것입니다. 열. 원하는 출력은 다음과 같습니다.

Name Repetition
A 2
B 4
C 1
B 2

해결 방법

이 문제를 해결하는 한 가지 접근 방식은 행 번호 개념을 사용한 다음 두 숫자 간의 차이를 계산하여 식별하는 것입니다. 연속 발생. 다음 쿼리는 이 접근 방식을 보여줍니다.

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;

설명

쿼리의 하위 쿼리:

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

각 행 번호를 계산합니다. 't' 테이블의 행. row_number() 함수는 각 행에 일련 번호를 할당하는 반면, partition by 절은 "이름" 열의 각 고유 값에 대해 행 번호가 재설정되도록 합니다. 그러면 "Name"과 "Id"의 각 조합에 대해 연속적으로 나타나는 그룹을 나타내는 'grp' 열이 생성됩니다.

그런 다음 외부 쿼리는 'grp' 열을 기준으로 결과를 그룹화하고 개수를 셉니다. 각 'grp' 및 'Name' 조합의 발생 횟수입니다. 이렇게 하면 "이름" 열에 있는 각 값의 연속 발생 횟수를 계산하는 최종 결과가 제공됩니다.

행 번호 간의 차이를 활용하여 이 접근 방식은 지정된 열에 있는 값의 연속 발생 횟수를 정확하게 판별하고 다음을 생성합니다. 원하는 출력.

위 내용은 데이터베이스 열에서 연속 값 발생을 계산하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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