>데이터 베이스 >MySQL 튜토리얼 >SQL 조인을 사용하여 그룹당 최대/최소 값을 효율적으로 찾는 방법은 무엇입니까?

SQL 조인을 사용하여 그룹당 최대/최소 값을 효율적으로 찾는 방법은 무엇입니까?

DDD
DDD원래의
2025-01-02 13:41:38487검색

How to Efficiently Find Max/Min Values per Group Using SQL Joins?

조인을 사용하여 그룹당 최대/최소 값 검색

이 솔루션에서는 조인 작업을 사용하여 지정된 열에 대해 최고 또는 최저 값이 있는 행을 검색합니다. 순위나 하위 쿼리를 사용하지 않고 각 그룹마다 OrderField 값이 가장 높은 행을 찾습니다.

그룹:

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 값이 가장 큰 행이 반환됩니다.

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

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