>데이터 베이스 >MySQL 튜토리얼 >MySQL에서 각 ID에 대해 가장 높은 버전 ID를 가진 행을 선택하는 방법은 무엇입니까?

MySQL에서 각 ID에 대해 가장 높은 버전 ID를 가진 행을 선택하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-29 01:12:10893검색

How to Select the Row with the Highest Version ID for Each ID in MySQL?

MySQL: 그룹에서 반환된 행 선택 제어

MySQL에서는 각 ID에 대해 가장 높은 버전이 있는 행을 검색할 수 있습니다. 복잡한 작업. 그러나 이 목표를 달성하기 위해 사용할 수 있는 접근 방식은 여러 가지가 있습니다.

하위 쿼리를 활용하는 방법도 있습니다.

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

이 하위 쿼리는 행을 버전 ID별로 내림차순으로 정렬합니다. 각 아이디. 이어서 기본 쿼리는 정렬된 행을 ID별로 그룹화합니다. 이 접근 방식은 메모리에 임시 테이블을 생성하지만 (id, version_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에 대한 최대 버전 ID를 계산합니다. 그런 다음 기본 쿼리는 ID 및 version_id 열을 사용하여 하위 쿼리를 원래 테이블과 조인하여 최대 버전 ID가 있는 행을 검색합니다.

두 방법 모두 각 ID에 대해 버전 ID가 가장 높은 행을 선택하기 위한 효과적인 솔루션을 제공합니다. . 가장 적절한 접근 방식은 애플리케이션의 특정 요구 사항과 성능 고려 사항에 따라 다릅니다.

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

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