>데이터 베이스 >MySQL 튜토리얼 >테이블에서 가장 최근의 고유한 레코드 3개를 선택하는 방법은 무엇입니까?

테이블에서 가장 최근의 고유한 레코드 3개를 선택하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-01 04:59:09777검색

How to Select the 3 Most Recent Distinct Records from a Table?

최근 고유 레코드 선택

쿼리의 목표는 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를 얻습니다. otheridentifier.
  • 그런 다음 기본 쿼리는 이 ID를 사용하여 원본 테이블에서 해당 레코드를 검색합니다.
  • 레코드는 시간 내림차순으로 정렬되며 가장 최근 3개는 LIMIT 3으로 제한됩니다.

이 접근 방식을 사용하면 쿼리는 예상 결과인 ID 5, 4, 2를 반환하며 이는 가장 최근 3개 항목을 나타냅니다. 고유한 otheridentifier 값을 가진 레코드입니다.

위 내용은 테이블에서 가장 최근의 고유한 레코드 3개를 선택하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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