집 >데이터 베이스 >MySQL 튜토리얼 >데이터베이스 테이블에서 동일한 ID의 최대값을 효율적으로 검색하는 방법은 무엇입니까?
동일한 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!