>데이터 베이스 >MySQL 튜토리얼 >MySQL에서 각 메소드 및 ID 조합에 대한 최신 레코드를 찾는 방법은 무엇입니까?

MySQL에서 각 메소드 및 ID 조합에 대한 최신 레코드를 찾는 방법은 무엇입니까?

DDD
DDD원래의
2025-01-03 07:16:38708검색

How to Find the Most Recent Records for Each Method and ID Combination in MySQL?

MySQL 테이블에서 필드 조합에 대한 가장 최근 레코드를 선택하는 방법

제공된 MySQL 테이블인 rpc_responses는 응답을 저장합니다. 타임스탬프, 메소드, ID 및 응답을 포함한 필드를 사용하여 RPC 호출에 적용됩니다. 목표는 메소드와 ID의 고유한 조합에 대한 최신 응답을 검색하는 것입니다.

이를 달성하기 위해 윈도우 절과 함께 MySQL의 ROW_NUMBER() 함수를 활용할 수 있습니다.

SELECT *
FROM (
    SELECT *, 
            ROW_NUMBER() OVER (PARTITION BY method, id ORDER BY timestamp DESC) AS row_num
    FROM rpc_responses
) AS subquery
WHERE row_num = 1

이것은 쿼리는 하위 쿼리를 사용하여 타임스탬프 필드를 기준으로 내림차순으로 정렬된 메서드와 ID의 각 개별 조합에 대한 행 번호를 계산합니다. 그런 다음 외부 쿼리는 결과를 필터링하여 각 조합의 가장 최근 레코드를 나타내는 행 번호 1이 있는 행만 선택합니다.

이 접근 방식은 복잡한 조인이나 임시 테이블 없이도 원하는 데이터를 효율적으로 검색해야 합니다. .

위 내용은 MySQL에서 각 메소드 및 ID 조합에 대한 최신 레코드를 찾는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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