최근 고유 레코드 선택
쿼리의 목표는 otheridentifier 열의 값이 서로 다른 테이블에서 가장 최근 레코드 3개를 검색하는 것입니다. . 그러나 GROUP BY 및 LIMIT를 사용하는 현재 접근 방식은 예상치 못한 결과를 낳습니다.
문제를 살펴보겠습니다. GROUP BY 연산은 행을 동일한 otheridentifier와 결합합니다. 그룹화 후에 순서가 지정되므로 각 그룹의 가장 최근 레코드가 반드시 선택되는 것은 아닙니다.
하위 쿼리를 사용한 솔루션
이 문제를 해결하려면 하위 쿼리를 사용하여 그룹을 식별할 수 있습니다. 각각의 고유한 기타 식별자에 대한 최신 기록입니다. 그런 다음 이 정보는 기본 쿼리에서 사용되어 원하는 레코드를 선택합니다.
다음 쿼리를 사용하면 됩니다.
SELECT * FROM `table` WHERE `id` = ( SELECT `id` FROM `table` as `alt` WHERE `alt`.`otheridentifier` = `table`.`otheridentifier` ORDER BY `time` DESC LIMIT 1 ) ORDER BY `time` DESC LIMIT 3
설명:
이 접근 방식을 사용하면 쿼리는 예상 결과인 ID 5, 4, 2를 반환하며 이는 가장 최근 3개 항목을 나타냅니다. 고유한 otheridentifier 값을 가진 레코드입니다.
위 내용은 테이블에서 가장 최근의 고유한 레코드 3개를 선택하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!