집 >데이터 베이스 >MySQL 튜토리얼 >PostgreSQL에서 특정 열을 기준으로 정렬된 그룹당 상위 N 행을 선택하는 방법은 무엇입니까?
PostgreSQL의 그룹 제한: 사용자 정의 열로 정렬된 각 그룹의 상위 N개 행 선택
사용자 정의 열 순서에 따라 각 그룹의 상위 N개 행을 검색하기 위해 PostgreSQL은 사용자(특히 PostgreSQL 8.4 이상을 사용하는 사용자)를 위한 솔루션을 제공합니다.
'id', 'section_id' 및 'name' 열이 포함된 예제 테이블을 생각해 보세요.
id | section_id | name |
---|---|---|
1 | 1 | A |
2 | 1 | B |
3 | 1 | C |
4 | 1 | D |
5 | 2 | E |
6 | 2 | F |
7 | 3 | G |
8 | 2 | H |
제공된 데이터를 기반으로 원하는 출력은 각 'section_id'에 대해 처음 두 행('이름'으로 정렬)을 선택하는 것입니다.
PostgreSQL 8.4 이상용 솔루션
<code class="language-sql">SELECT * FROM ( SELECT ROW_NUMBER() OVER (PARTITION BY section_id ORDER BY name) AS r, t.* FROM xxx t ) x WHERE x.r <= 2;</code>
이 고급 솔루션은 'PARTITION BY' 및 'ORDER BY' 절과 함께 'ROW_NUMBER()' 함수를 활용하여 원하는 결과 집합을 얻습니다. 'xxx' 테이블의 각 행에는 'name'을 기준으로 행이 정렬된 해당 'section_id' 그룹 내의 순위가 할당됩니다. 'x.r
위 내용은 PostgreSQL에서 특정 열을 기준으로 정렬된 그룹당 상위 N 행을 선택하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!