> 데이터 베이스 > MySQL 튜토리얼 > 데이터베이스의 각 그룹에 대한 최신 레코드를 효율적으로 검색하려면 어떻게 해야 합니까?

데이터베이스의 각 그룹에 대한 최신 레코드를 효율적으로 검색하려면 어떻게 해야 합니까?

Mary-Kate Olsen
풀어 주다: 2024-12-31 04:52:10
원래의
945명이 탐색했습니다.

How Can I Efficiently Retrieve the Latest Record for Each Group in a Database?

GROUP BY를 통해 그룹 내 최신 레코드 확인

유사한 그룹화 기준을 가진 여러 레코드가 포함된 데이터베이스 시나리오에서 일반적인 작업은 검색하는 것입니다. 각 그룹의 최신 기록. 이는 각 사용자의 가장 최근 메시지를 원하는 메시징 플랫폼에서 그 예가 됩니다.

초기 시도 및 단점

초기 접근 방식에서는 GROUP BY 절을 사용하여 다음을 수행합니다. 쿼리에 표시된 대로 레코드를 개별 그룹으로 집계합니다.

SELECT * FROM messages GROUP BY from_id
로그인 후 복사

그러나 이 쿼리는 가장 최근 메시지가 아닌 각 그룹 내에서 가장 오래된 메시지입니다.

쿼리 해결

각 그룹의 최신 기록을 얻으려면 보다 정교한 접근 방식이 필요합니다. 여기에는 다음이 포함됩니다.

  1. 하위 쿼리: 다음 하위 쿼리를 사용하여 각 그룹 내의 최신 타임스탬프 값을 결정합니다.

    SELECT from_id, MAX(timestamp) timestamp FROM messages GROUP BY from_id
    로그인 후 복사
  2. 하위 쿼리 가입: from_id 및 timestamp 열과 일치하는 하위 쿼리가 있는 원본 메시지 테이블 대응합니다.

    SELECT t1.* FROM messages t1
      JOIN (SELECT from_id, MAX(timestamp) timestamp FROM messages GROUP BY from_id) t2
     ON t1.from_id = t2.from_id AND t1.timestamp = t2.timestamp;
    로그인 후 복사

이 쿼리는 메시지 테이블의 각 from_id에 대한 최신 메시지를 생성하여 초기 문제를 해결합니다.

위 내용은 데이터베이스의 각 그룹에 대한 최신 레코드를 효율적으로 검색하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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