>데이터 베이스 >MySQL 튜토리얼 >PostgreSQL에서 특정 열을 기준으로 정렬된 그룹당 상위 N 행을 선택하는 방법은 무엇입니까?

PostgreSQL에서 특정 열을 기준으로 정렬된 그룹당 상위 N 행을 선택하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2025-01-15 11:19:45209검색

How to Select the Top N Rows per Group Ordered by a Specific Column in PostgreSQL?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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