>  기사  >  데이터 베이스  >  MySQL의 GROUP BY 절에서 각 ID의 최고 버전 기록을 검색하는 방법은 무엇입니까?

MySQL의 GROUP BY 절에서 각 ID의 최고 버전 기록을 검색하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-21 00:06:17643검색

How to Retrieve the Highest Version Record for Each ID in MySQL's GROUP BY Clause?

MySQL Group By에서 반환된 행 제어

MySQL에서는 데이터 그룹에서 원하는 행을 검색하는 것이 어려울 수 있습니다. 이 문서에서는 시나리오별로 그룹의 반환된 행에 대한 제어를 설정하는 방법을 살펴봅니다.

문제:

데이터베이스 테이블에 ID 열로 식별되는 여러 버전의 레코드가 포함되어 있습니다. version_id 열. 목표는 테이블을 쿼리하고 각 고유 ID에 대해 version_id가 가장 높은 레코드만 반환하는 것입니다.

해결책 1(하위 쿼리 접근 방식):

한 가지 접근 방식은 다음을 사용하는 것입니다. version_id를 기준으로 행의 순위를 내림차순으로 지정하는 하위 쿼리:

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

이 방법은 효과적으로 임시 테이블을 생성하고 데이터를 정렬한 다음 그룹화하여 원하는 행을 검색합니다.

해결책 2(Max 및 Joins 사용):

또 다른 방법은 MAX() 함수와 조인을 사용하여 동일한 결과를 얻습니다.

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

이 접근 방식은 먼저 최대 version_id를 식별합니다. 그런 다음 원본 테이블에 조인하여 가장 높은 버전의 전체 레코드를 얻습니다.

장점 및 고려 사항:

하위 쿼리 접근 방식은 메모리에 임시 테이블을 생성할 수 있습니다. 이는 대규모 데이터 세트의 성능에 영향을 미칠 수 있습니다. 반면에 이해하고 구현하는 것이 더 간단할 수 있습니다.

조인 기반 방법은 일반적으로 임시 테이블을 생성하지 않으므로 대규모 데이터세트에 더 효율적입니다. 하지만 최적의 성능을 위해서는 (id, version_id) 열에 인덱스가 있다고 가정합니다.

두 솔루션 모두 효율적인 실행을 위해서는 적절한 인덱스가 필요합니다.

위 내용은 MySQL의 GROUP BY 절에서 각 ID의 최고 버전 기록을 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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