연속 발생을 기준으로 값 그룹화
테이블에서 값의 연속 발생을 계산하는 효과적인 방법은 행의 차이를 계산하는 것입니다. 숫자입니다.
다음 사항을 고려하세요. query:
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;
이 하위 쿼리는 각 행에 대해 두 개의 행 번호를 생성합니다.
두 행 번호를 빼서 이름이 변경되거나 동일한 이름이 연속해서 나타날 때마다 증가하는 "그룹" 식별자(grp)를 생성합니다.
그런 다음 최종 쿼리는 이 grp를 기반으로 행을 그룹화하고 각 그룹 내에서 각 이름의 발생 횟수를 계산합니다. 이를 통해 원하는 연속 발생 횟수를 얻을 수 있습니다.
+------+------------+ | Name | Repetition | +------+------------+ | A | 2 | | B | 4 | | C | 1 | | B | 2 | +------+------------+
이 접근 방식은 행 번호의 차이를 그룹화 메커니즘으로 활용하여 테이블에서 연속 값을 식별하는 효율적인 방법을 제공합니다.
위 내용은 SQL 테이블에서 값의 연속 발생을 계산하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!