> 데이터 베이스 > MySQL 튜토리얼 > SQL의 그룹화된 데이터 세트에서 최대 날짜 및 해당 데이터를 검색하는 방법은 무엇입니까?

SQL의 그룹화된 데이터 세트에서 최대 날짜 및 해당 데이터를 검색하는 방법은 무엇입니까?

Patricia Arquette
풀어 주다: 2025-01-08 13:31:46
원래의
239명이 탐색했습니다.

How to Retrieve the Maximum Date and Corresponding Data from a Grouped Dataset in SQL?

그룹화된 SQL 레코드에서 최신 데이터 추출

데이터베이스 테이블에는 동일한 그룹에 대해 각각 날짜가 다른 여러 항목이 포함되는 경우가 많습니다. 특정 필터를 적용하면서 가장 최근 날짜의 기록에서 데이터를 식별하고 검색하는 것은 일반적인 데이터 분석 작업입니다. 이 과정은 SQL을 이용하여 효율적으로 처리할 수 있습니다.

2단계 접근 방식을 사용한 솔루션은 다음과 같습니다.

먼저 각 그룹의 최대 날짜를 찾습니다.

<code class="language-sql">SELECT group_id, MAX(record_date) AS max_date
FROM data_table
WHERE check_value > 0
GROUP BY group_id;</code>
로그인 후 복사

이 쿼리는 record_date가 0보다 큰 각 group_id에 대한 최신 check_value을 결정합니다. 참고: groupdate을 열 이름으로 사용하는 것은 SQL 키워드와의 잠재적 충돌로 인해 일반적으로 권장되지 않습니다. 대신 group_idrecord_date을 사용했습니다.

다음으로 이 결과를 원래 테이블에 다시 결합하여 전체 행 정보를 검색합니다.

<code class="language-sql">SELECT dt.group_id, dt.record_date, dt.check_value, dt.other_column
FROM data_table dt
INNER JOIN (
    SELECT group_id, MAX(record_date) AS max_date
    FROM data_table
    WHERE check_value > 0
    GROUP BY group_id
) AS max_dates ON dt.group_id = max_dates.group_id AND dt.record_date = max_dates.max_date;</code>
로그인 후 복사

INNER JOIN는 첫 번째 쿼리의 결과를 원본 테이블(data_table)과 결합하여 group_idrecord_date이 하위 쿼리에서 식별된 최대 날짜와 일치하는 행만 선택합니다. 이는 지정된 기준을 충족하는 각 그룹의 가장 최근 레코드에 대한 전체 행 데이터를 제공합니다. other_column은 검색하려는 추가 열을 나타냅니다. data_table, group_id, record_date, check_valueother_column을 실제 테이블 및 열 이름으로 바꿔야 합니다.

위 내용은 SQL의 그룹화된 데이터 세트에서 최대 날짜 및 해당 데이터를 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿