테이블에서 값의 연속 발생 횟수 계산
값 열이 포함된 테이블이 있는 데이터베이스에서 연속 발생 횟수 확인 각 값을 선택하는 것은 다양한 데이터 분석 시나리오에 유용한 작업이 될 수 있습니다. 이 질문은 효율적인 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!