MySQL에서 상위 N개 최대값을 효율적으로 식별하는 방법은 무엇입니까?

DDD
풀어 주다: 2024-11-12 05:40:01
원래의
830명이 탐색했습니다.

How to Efficiently Identify the Top N Maximum Values in MySQL?

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

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿