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