MySQL에서 상위 N개 최대값 식별
많은 시나리오에서 특정 열에서 가장 높은 값을 가진 상위 N개 행을 쿼리합니다. 결정적이다. 그러나 여러 행이 동일한 최대값을 공유하는 경우를 처리하는 방법과 동일한 값을 가진 모든 행을 포함할지 아니면 상위 N개만 포함할지 여부에 대해 혼란이 있을 수 있습니다.
이 문제를 해결하려면 다음을 활용할 수 있습니다. 다음 방법:
옵션 1: 정확한 상위 N
LIMIT 절을 사용하면 다음과 같은 행을 제외하고 값을 기준으로 내림차순으로 정확한 상위 N개 행을 검색할 수 있습니다. 동일한 값:
SELECT * FROM t ORDER BY value DESC LIMIT N
옵션 2: 상위 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.cutoff
또는 다음 방법을 사용할 수 있습니다. 단순화된 버전:
SELECT * FROM t JOIN ( SELECT value FROM t ORDER BY value LIMIT N ) tlim ON t.value = tlim.value
개념적 대안(선택 사항)
다음 쿼리는 개념적으로 원하는 동작을 캡처하지만 MySQL에서는 작동하지 않을 수 있습니다.
SELECT * FROM t WHERE t.value >= ANY (SELECT value FROM t ORDER BY value LIMIT N)
위 내용은 MySQL에서 상위 N개 최대값을 효율적으로 식별하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!