>데이터 베이스 >MySQL 튜토리얼 >데이터베이스 테이블에서 동일한 ID의 최대값을 효율적으로 검색하는 방법은 무엇입니까?

데이터베이스 테이블에서 동일한 ID의 최대값을 효율적으로 검색하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2025-01-06 12:42:40198검색

How to Efficiently Retrieve the Maximum Value for Identical IDs in a Database Table?

동일한 ID에 대한 최대값 쿼리

동일한 ID를 공유하는 여러 레코드가 있는 테이블에서 다음을 수행해야 하는 시나리오가 발생할 수 있습니다. 각 ID의 최대값을 검색합니다. 이를 달성하기 위한 쿼리는 다음과 같습니다.

하위 쿼리 접근 방식:

select cur.id, cur.signal, cur.station, cur.ownerid
from yourtable cur
where not exists (
    select *
    from yourtable high
    where high.id = cur.id and high.signal > cur.signal
)

이 쿼리는 "NOT EXISTS" 절이 있는 하위 쿼리를 사용하여 더 높은 값을 가진 모든 행을 제외합니다. 현재 행보다 신호를 보냅니다. 이를 통해 각 ID별로 신호가 가장 많은 행을 선택하게 됩니다. 잠재적인 단점은 최대값이 동일한 ID에 대해 여러 행을 나열할 수 있다는 것입니다.

외부 조인 접근 방식:

대체 접근 방식은 외부 조인을 사용하는 것입니다. self-join:

select a.id, a.signal, a.station, a.ownerid
from yourtable a
left join yourtable b on a.id = b.id and a.signal < b.signal
where b.id is null

이 쿼리는 외부 조인을 사용하여 더 높은 신호가 없는 행을 찾습니다. 조인된 행에서 null 값을 확인하는 조건을 적용하여 신호가 낮은 행을 필터링합니다. 이 접근 방식은 최대 신호가 있는 각 ID에 대한 단일 행을 보장합니다.

예:

제공된 테이블을 사용하면 쿼리는 다음 결과를 반환합니다.

하위 쿼리 접근 방식:

ID Signal Station OwnerID
111 -120 Home 1
222 -95 Work 1

외부 조인 접근 방식:

ID Signal Station OwnerID
111 -120 Home 1
222 -95 Work 1

결론:

두 접근 방식 모두 각 ID의 최대 신호 값을 검색하는 동일한 목표입니다. 하위 쿼리 접근 방식은 작은 데이터세트에 더 효율적일 수 있는 반면, 외부 조인 접근 방식은 대규모 데이터세트에 더 효율적일 수 있으며, 특히 동일한 신호가 있는 여러 행이 있는 경우 더욱 그렇습니다.

위 내용은 데이터베이스 테이블에서 동일한 ID의 최대값을 효율적으로 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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