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