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