>데이터 베이스 >MySQL 튜토리얼 >MySQL에서 상위 N개 행을 검색할 때 중복된 최대값을 처리하는 방법은 무엇입니까?

MySQL에서 상위 N개 행을 검색할 때 중복된 최대값을 처리하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-10 20:25:03882검색

How to Handle Duplicate Maximum Values When Retrieving Top N Rows in MySQL?

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

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