>데이터 베이스 >MySQL 튜토리얼 >상위 N개 SQL 쿼리에 중복된 최대값이 포함되어야 합니까?

상위 N개 SQL 쿼리에 중복된 최대값이 포함되어야 합니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-14 15:26:02500검색

Should Top N SQL Queries Include Duplicate Maximum Values?

MySQL 테이블에서 상위 N개의 가장 높은 값 찾기

데이터 분석 및 보고에서는 다음을 기반으로 상위 레코드를 검색해야 하는 경우가 많습니다. 특정 열의 가장 높은 값. 그러나 여러 레코드가 N번째 위치 근처에서 동일한 최대값을 공유하는 경우 모호성이 발생할 수 있습니다.

질문:

SQL을 사용하여 가장 높은 값이 포함된 상위 N개 행을 선택할 때 특정 열의 값에 대한 쿼리는 상위 N개 행만 반환해야 합니까, 아니면 동일한 최대값을 가진 추가 행을 포함해야 합니까?

답변:

답은 다음 여부에 따라 다릅니다. 중복된 상위 값을 포함하거나 제외하려고 합니다. 다음은 두 가지 접근 방식입니다.

접근 방법 1: 중복된 상위 값 제외

중복 없이 상위 N개 행만 검색하려면 다음 쿼리를 사용합니다.

SELECT *
FROM t
ORDER BY value DESC
LIMIT N

이 쿼리에서 LIMIT N 절은 결과 집합을 상위 N개 행으로 제한하고 N번째 행 아래 최대값이 동일한 행은 제외합니다.

접근법 2: 중복 상단 포함 값

중복 여부에 관계없이 가장 높은 값을 가진 모든 행을 검색하려면 다음 쿼리를 사용합니다.

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;

이 쿼리는 하위 쿼리를 사용하여 다음이 있는 행의 구분 값을 결정합니다. N번째로 높은 값입니다. 그런 다음 ON 절을 사용하여 이 하위 쿼리를 기본 테이블과 조인하여 컷오프보다 크거나 같은 값을 가진 행을 필터링합니다.

추가 고려 사항:

  • 여러 행의 최대값이 동일하고 N번째 행이 중복되지 않는 경우 접근 방식 1은 상위 N개 행만 반환합니다.
  • 접근 방식 2는 여부에 관계없이 항상 N번째 가장 높은 값을 가진 모든 행을 반환합니다. 중복인지 아닌지입니다.
  • 테이블 크기와 인덱싱에 따라 쿼리 성능이 달라질 수 있습니다.

위 내용은 상위 N개 SQL 쿼리에 중복된 최대값이 포함되어야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.