> 데이터 베이스 > MySQL 튜토리얼 > PostgreSQL에서 각 범주의 최대 날짜 ID를 검색하는 방법은 무엇입니까?

PostgreSQL에서 각 범주의 최대 날짜 ID를 검색하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2025-01-03 01:58:38
원래의
414명이 탐색했습니다.

How to Retrieve the Maximum Date ID for Each Category in PostgreSQL?

PostgreSQL에서 범주별로 그룹화된 최대 날짜 ID 검색

데이터베이스 작업에서는 특정 기준에 따라 레코드를 검색해야 하는 경우가 많습니다. 그러한 작업 중 하나는 주어진 데이터 세트의 각 카테고리에 대한 최대 날짜가 있는 ID를 선택하는 것입니다. 이는 PostgreSQL에서 DISTINCT ON 절을 사용하여 효과적으로 달성할 수 있습니다.

다음 샘플 데이터를 고려하세요.

id  category  date
1   a         2013-01-01
2   b         2013-01-03
3   c         2013-01-02
4   a         2013-01-02
5   b         2013-01-02
6   c         2013-01-03
7   a         2013-01-03
8   b         2013-01-01
9   c         2013-01-01
로그인 후 복사

각 ID에 대해 최대 날짜가 있는 ID를 선택하려면 카테고리에서 다음을 사용할 수 있습니다. 쿼리:

SELECT DISTINCT ON (category)
       id  -- , category, date  -- any other column (expression) from the same row
FROM   tbl
ORDER  BY category, date DESC;
로그인 후 복사

설명:

  • DISTINCT ON(범주): 이 절은 중복 범주가 제거되어 정렬을 만족하는 첫 번째 고유 카테고리를 선택합니다. 기준.
  • date DESC: 이 내림차순 정렬 순서를 사용하면 각 범주에 대해 최대 날짜가 있는 레코드가 먼저 검색됩니다.

이 쿼리의 결과 다음과 같습니다.

7
2
6
로그인 후 복사

DISTINCT ON은 다음과 같은 경우에 특히 유용합니다. 동일한 최대 날짜를 가진 여러 레코드가 존재합니다. 이러한 경우 카테고리별로 첫 번째 고유 레코드를 선택할 수 있는 방법을 제공합니다.

위 내용은 PostgreSQL에서 각 범주의 최대 날짜 ID를 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿