MySQL에서 상위 N개 최대값 선택
가장 높은 값을 가진 상위 N개 행을 검색할 때 올바른 동작을 결정하는 것은 어려울 수 있습니다. 특히 다음과 같은 경우에는 더욱 그렇습니다. 여러 행이 동일한 최대값을 공유합니다. 이 문서에서는 상위 N개 행만 반환할지 아니면 동일한 값을 가진 추가 행을 포함할지에 대한 질문을 다룹니다.
상위 N개의 개별 행을 얻으려면 다음 쿼리를 사용할 수 있습니다.
select * from t order by value desc limit N;
이 쿼리는 값 열의 내림차순을 기준으로 상위 N개 행을 검색합니다. 그러나 여러 행이 N번째 최대값을 공유하는 경우 동일한 값을 가진 행을 제외하고 상위 N개 행만 반환합니다.
동일한 최대값을 가진 모든 행을 반환해야 하는 시나리오에서는 다음 쿼리를 사용할 수 있습니다.
select * from t join (select min(value) as cutoff from (select value from t order by value limit N ) tlim ) tlim on t.value >= tlim;
또는 위 쿼리의 단순화된 버전을 사용할 수 있습니다. 사용됨:
select * from t join (select value from t order by value limit N ) tlim on t.value = tlim.value;
이 두 쿼리는 모두 상위 N개 행뿐만 아니라 동일한 최대값을 공유하는 추가 행도 반환합니다.
다음 쿼리는 개념적으로 원하는 결과를 달성하지만, 데이터베이스 특정 제한으로 인해 MySQL과 호환되지 않을 수 있습니다.
select * from t where t.value >= ANY (select value from t order by value limit N)
사용 가능한 다양한 방법을 이해함으로써 개발자는 특정 조건에 따라 적절한 쿼리를 선택할 수 있습니다. MySQL에서 상위 N개 최대값을 검색할 때 요구 사항.
위 내용은 MySQL에서 상위 N개 행을 검색할 때 중복된 최대값을 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!