>데이터 베이스 >MySQL 튜토리얼 >테이블의 각 고유 ID에 대해 최소 Record_Date가 있는 행을 선택하는 방법은 무엇입니까?

테이블의 각 고유 ID에 대해 최소 Record_Date가 있는 행을 선택하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-17 20:20:13473검색

How to Select Rows with the Minimum Record_Date for Each Unique ID in a Table?

각 고유 ID에 대해 기록 날짜가 가장 빠른 행 검색

중복 id 값이 포함된 테이블로 작업하고 각 고유 record_date에 대해 가장 빠른 id이 있는 행만 선택해야 하는 것은 까다로울 수 있습니다. record_date 값이 고유하지 않을 때 표준 방법은 종종 어려움을 겪습니다. 이 솔루션은 다음과 같은 시나리오를 효율적으로 처리합니다.

다음 SQL 쿼리는 원하는 행을 효과적으로 선택합니다.

<code class="language-sql">SELECT mt.*
FROM MyTable mt
INNER JOIN (
    SELECT id, MIN(record_date) AS MinDate
    FROM MyTable
    GROUP BY id
) t ON mt.id = t.id AND mt.record_date = t.MinDate;</code>

이 쿼리는 하위 쿼리를 사용하여 먼저 각 record_date에 대한 최소 id를 결정합니다. 하위 쿼리는 행을 id으로 그룹화한 다음 MIN() 함수를 사용하여 각 그룹 내에서 최소 record_date를 찾습니다.

그런 다음 외부 쿼리는 MyTableid을 모두 사용하여 하위 쿼리의 결과를 원래 테이블(record_date)에 다시 조인합니다. 이렇게 하면 각 record_date에 대한 최소 id과 일치하는 행만 최종 결과 집합에 포함됩니다. 이렇게 하면 중복 항목이 효과적으로 제거되고 각 고유 record_date.id에 대해 가장 빠른

행만 반환됩니다.

위 내용은 테이블의 각 고유 ID에 대해 최소 Record_Date가 있는 행을 선택하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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