집 >데이터 베이스 >MySQL 튜토리얼 >순위 함수를 사용하지 않고 SQL에서 그룹당 최소값과 최대값을 효율적으로 찾는 방법은 무엇입니까?
이 튜토리얼에서는 그룹당 최고값 또는 최소값이 있는 레코드를 검색하는 방법에 대한 질문을 다룹니다. 순위(@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를 0으로 재설정하려면 추가 파생 테이블을 도입해야 하지만 이로 인해 최적화가 제대로 이루어지지 않을 수 있습니다.
위 내용은 순위 함수를 사용하지 않고 SQL에서 그룹당 최소값과 최대값을 효율적으로 찾는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!