>데이터 베이스 >MySQL 튜토리얼 >MySQL에서 그룹별 최대값을 선택하는 방법은 무엇입니까?

MySQL에서 그룹별 최대값을 선택하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-22 09:56:111038검색

How to Select the Group-Wise Maximum in MySQL?

MySQL에서 그룹별 최대값 선택

관계형 데이터베이스에서는 각 그룹에 대해 특정 열의 최대값이 있는 행을 검색해야 하는 경우가 있습니다. 이를 그룹별 최대값 선택이라고 합니다. MySQL에는 이를 수행하기 위한 여러 접근 방식이 있습니다.

하위 쿼리 방법

한 가지 효율적인 방법은 하위 쿼리를 사용하는 것입니다.

SELECT *
FROM (
  SELECT id, MAX(version_id) AS version_id
  FROM table
  GROUP BY id
) AS t1
INNER JOIN table AS t2
  ON t2.id = t1.id AND t1.version_id = t2.version_id;

이 하위 쿼리는 각 ID의 최대 버전 ID를 지정한 다음 이를 원래 테이블과 조인하여 해당 행을 검색합니다. 이는 상대적으로 효율적이며 (id, version_id) 열에 인덱스가 있다고 가정합니다.

집계 및 순위 지정 방법

또는 집계 및 순위 지정 기능을 사용할 수 있습니다.

SELECT id,
       version_id,
       field1,
       field2
FROM (
  SELECT id,
          version_id,
          field1,
          field2,
          RANK() OVER (PARTITION BY id ORDER BY version_id DESC) AS ranking
  FROM table
) AS ranked_table
WHERE ranking = 1;

이 쿼리는 각 ID의 행을 version_id의 내림차순으로 순위를 매기고 순위가 다음과 같은 행을 선택합니다. 1, 최대 버전을 효과적으로 필터링합니다.

창 함수

창 함수도 이 목적으로 사용할 수 있습니다.

SELECT id,
       version_id,
       field1,
       field2
FROM (
  SELECT id,
          version_id,
          field1,
          field2,
          MAX(version_id) OVER (PARTITION BY id) AS max_version_id
  FROM table
) AS windowed_table
WHERE version_id = max_version_id;

이 쿼리는 에 대한 최대 버전 ID를 계산합니다. MAX() over() 창 함수를 사용하여 각 ID를 선택하고 버전 ID가 일치하는 행을 선택합니다.

위 내용은 MySQL에서 그룹별 최대값을 선택하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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