GROUP BY를 통해 그룹 내 최신 레코드 확인
유사한 그룹화 기준을 가진 여러 레코드가 포함된 데이터베이스 시나리오에서 일반적인 작업은 검색하는 것입니다. 각 그룹의 최신 기록. 이는 각 사용자의 가장 최근 메시지를 원하는 메시징 플랫폼에서 그 예가 됩니다.
초기 시도 및 단점
초기 접근 방식에서는 GROUP BY 절을 사용하여 다음을 수행합니다. 쿼리에 표시된 대로 레코드를 개별 그룹으로 집계합니다.
SELECT * FROM messages GROUP BY from_id
그러나 이 쿼리는 가장 최근 메시지가 아닌 각 그룹 내에서 가장 오래된 메시지입니다.
쿼리 해결
각 그룹의 최신 기록을 얻으려면 보다 정교한 접근 방식이 필요합니다. 여기에는 다음이 포함됩니다.
하위 쿼리: 다음 하위 쿼리를 사용하여 각 그룹 내의 최신 타임스탬프 값을 결정합니다.
SELECT from_id, MAX(timestamp) timestamp FROM messages GROUP BY from_id
하위 쿼리 가입: 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!