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