>데이터 베이스 >MySQL 튜토리얼 >순위 함수를 사용하지 않고 SQL에서 그룹당 최소값과 최대값을 효율적으로 찾는 방법은 무엇입니까?

순위 함수를 사용하지 않고 SQL에서 그룹당 최소값과 최대값을 효율적으로 찾는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-23 22:32:17742검색

How to Efficiently Find Minimum and Maximum Values per Group in SQL Without Using Ranking Functions?

그룹당 최고값 및 최소값 가져오기

개요

이 튜토리얼에서는 그룹당 최고값 또는 최소값이 있는 레코드를 검색하는 방법에 대한 질문을 다룹니다. 순위(@Rank)에 의존하지 않고 각 그룹 내에서 지정된 필드. 이 초기 질문에서는 @Rank를 솔루션으로 사용했지만 후속 응답에서는 조인을 사용하는 보다 효율적인 접근 방식을 보여줍니다.

솔루션

각 그룹에 대해 OrderField가 가장 높은 행을 얻으려면 왼쪽 외부를 사용합니다. Join 및 다음 쿼리:

SELECT t1.*
FROM `Table` AS t1
LEFT OUTER JOIN `Table` AS t2
  ON t1.GroupId = t2.GroupId AND t1.OrderField < t2.OrderField
WHERE t2.GroupId IS NULL
ORDER BY t1.OrderField;

그룹 내에서 여러 레코드에 동일한 OrderField가 있고 그 중 하나가 필요한 경우 조건은 다음과 같습니다.

SELECT t1.*
FROM `Table` AS t1
LEFT OUTER JOIN `Table` AS t2
  ON t1.GroupId = t2.GroupId 
        AND (t1.OrderField < t2.OrderField 
         OR (t1.OrderField = t2.OrderField AND t1.Id < t2.Id))
WHERE t2.GroupId IS NULL

이 세련된 쿼리는 더 높은 OrderField 값 또는 더 낮은 Id 값을 가진 동일한 OrderField를 갖는 동일한 그룹 GroupId 내에 다른 행 t2가 없는 경우에만 t1이 반환되도록 보장합니다. 따라서 각 그룹 내에서 OrderField가 가장 큰 행을 효과적으로 검색합니다.

최적화

왼쪽 외부 조인 접근 방식을 사용하면 @Rank 및 하위 쿼리가 포함된 이전 방법에 비해 쿼리 성능이 크게 향상될 수 있습니다. 왼쪽 외부 조인은 최적화된 액세스를 위해 (GroupId, OrderField)에 대한 인덱스를 활용할 수 있습니다.

@Rank 관련 주의 사항

@Rank를 사용하는 초기 접근 방식은 다음과 같은 이유로 예상대로 작동하지 않을 수 있습니다. @Rank 증가는 첫 번째 테이블이 처리된 후에도 계속됩니다. 테이블 간에 @Rank를 0으로 재설정하려면 추가 파생 테이블을 도입해야 하지만 이로 인해 최적화가 제대로 이루어지지 않을 수 있습니다.

위 내용은 순위 함수를 사용하지 않고 SQL에서 그룹당 최소값과 최대값을 효율적으로 찾는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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