>데이터 베이스 >MySQL 튜토리얼 >MySQL의 각 그룹에서 가장 높은 값을 가진 행을 선택하는 방법은 무엇입니까?

MySQL의 각 그룹에서 가장 높은 값을 가진 행을 선택하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-24 08:02:11654검색

How to Select the Row with the Highest Value in Each Group in MySQL?

MySQL: 그룹 BY 쿼리에서 반환되는 행 제어

MySQL에서 각 그룹에서 가장 높은 값을 가진 행을 검색하는 것은 다음과 같습니다. 일반적인 작업. 그러나 ORDER BY와 함께 표준 GROUP BY 절을 사용하면 예상치 못한 결과가 발생할 수 있습니다.

이를 달성하기 위해 기본 그룹화 동작을 재정의하는 대체 접근 방식을 사용할 수 있습니다.

하위 쿼리 방법:

이 방법에는 각 고유에 대한 최대 version_id를 얻기 위해 하위 쿼리를 생성하는 작업이 포함됩니다. id:

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

이 쿼리는 각 ID에 대해 최대 version_id를 선택하는 하위 쿼리와 원본 테이블을 조인합니다. 조인을 사용하면 version_id가 가장 높은 행만 반환됩니다.

ORDER BY 트릭을 사용한 하위 쿼리:

하위 쿼리 방법의 변형에는 특정 순서를 보장하기 위한 하위 쿼리:

SELECT *
FROM (SELECT * FROM table ORDER BY version_id DESC) t1
GROUP BY t1.id

이 쿼리는 행을 내림차순으로 효과적으로 정렬합니다. 그룹화를 수행하기 전에 각 그룹 내에서 version_id를 확인하여 가장 높은 version_id가 있는 행이 각 그룹에 대해 유지되도록 합니다.

명명된 Windows 함수:

창 함수를 사용하면 계산이 가능합니다. 이 작업에 사용할 수 있는 창에 정의된 행 집합 내에서 수행됩니다.

SELECT *
FROM (
  SELECT *, ROW_NUMBER() OVER (PARTITION BY id ORDER BY version_id DESC) AS rn
  FROM table
) t
WHERE rn = 1

이 쿼리 ROW_NUMBER로 정의된 파티션 내의 각 고유 ID에 대한 행 번호를 계산합니다. WHERE 절은 행 번호가 1이 아닌 행을 필터링하여 각 ID에 대해 version_id가 가장 높은 행만 반환되도록 합니다.

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

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