관계형 데이터베이스에서는 각 그룹에 대해 특정 열의 최대값이 있는 행을 검색해야 하는 경우가 있습니다. 이를 그룹별 최대값 선택이라고 합니다. MySQL에는 이를 수행하기 위한 여러 접근 방식이 있습니다.
한 가지 효율적인 방법은 하위 쿼리를 사용하는 것입니다.
SELECT * FROM ( SELECT id, MAX(version_id) AS version_id FROM table GROUP BY id ) AS t1 INNER JOIN table AS t2 ON t2.id = t1.id AND t1.version_id = t2.version_id;
이 하위 쿼리는 각 ID의 최대 버전 ID를 지정한 다음 이를 원래 테이블과 조인하여 해당 행을 검색합니다. 이는 상대적으로 효율적이며 (id, version_id) 열에 인덱스가 있다고 가정합니다.
또는 집계 및 순위 지정 기능을 사용할 수 있습니다.
SELECT id, version_id, field1, field2 FROM ( SELECT id, version_id, field1, field2, RANK() OVER (PARTITION BY id ORDER BY version_id DESC) AS ranking FROM table ) AS ranked_table WHERE ranking = 1;
이 쿼리는 각 ID의 행을 version_id의 내림차순으로 순위를 매기고 순위가 다음과 같은 행을 선택합니다. 1, 최대 버전을 효과적으로 필터링합니다.
창 함수도 이 목적으로 사용할 수 있습니다.
SELECT id, version_id, field1, field2 FROM ( SELECT id, version_id, field1, field2, MAX(version_id) OVER (PARTITION BY id) AS max_version_id FROM table ) AS windowed_table WHERE version_id = max_version_id;
이 쿼리는 에 대한 최대 버전 ID를 계산합니다. MAX() over() 창 함수를 사용하여 각 ID를 선택하고 버전 ID가 일치하는 행을 선택합니다.
위 내용은 MySQL에서 그룹별 최대값을 선택하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!