집 >데이터 베이스 >MySQL 튜토리얼 >데이터베이스 열에서 연속 값 발생을 계산하는 방법은 무엇입니까?
테이블 열의 연속 발생 횟수를 계산하는 방법
테이블의 데이터로 작업할 때 연속 발생 횟수를 계산하는 것이 유용할 수 있습니다. 특정 열에서 값이 연속적으로 발생하는 횟수입니다. 예를 들어, 테이블에 직원 이름을 나타내는 열이 포함되어 있는 경우 동일한 직원 이름이 행에 나타나는 횟수를 알고 싶을 수 있습니다.
문제
다음 표를 고려하세요.
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!