>데이터 베이스 >MySQL 튜토리얼 >데이터베이스 테이블의 각 키에 대한 가장 최근 값을 효율적으로 선택하는 방법은 무엇입니까?

데이터베이스 테이블의 각 키에 대한 가장 최근 값을 효율적으로 선택하는 방법은 무엇입니까?

DDD
DDD원래의
2024-12-31 20:25:191055검색

How to Efficiently Select the Most Recent Values for Each Key in a Database Table?

데이터베이스 테이블의 각 키에 대해 가장 최근 값 선택

센서 데이터 또는 기타 타임스탬프 정보가 포함된 테이블로 작업할 때 각 개별 키 값에 대한 최신 항목을 검색하는 데 필요한 경우가 많습니다. 키를 기준으로 그룹화하고 최대 타임스탬프를 기준으로 정렬하는 간단한 접근 방식은 직관적으로 보일 수 있지만 집계에 키가 아닌 필드가 포함되어 오류가 발생할 수 있습니다.

하위 쿼리를 사용하는 대체 솔루션 :

각 키의 최대 타임스탬프를 식별하는 하위 쿼리를 사용하여 이 문제를 해결하는 한 가지 신뢰할 수 있는 방법 값:

SELECT sensorID,
       timestamp,
       sensorField1,
       sensorField2
FROM sensorTable
WHERE timestamp = (SELECT MAX(timestamp) FROM sensorTable WHERE sensorID = sensorTable.sensorID)
ORDER BY sensorID, timestamp;

이 쿼리에서:

  • 기본 테이블 sensorTable에 두 번 액세스했습니다.
  • 내부 하위 쿼리는 최대 타임스탬프(MAX(timestamp))를 검색합니다. ) 각 센서 ID에 대해 이를 기본 테이블의 해당 타임스탬프와 비교합니다.
  • 행 각 키 값에 대해 가장 최근의 타임스탬프가 선택됩니다.
  • 검색된 열에는 sensorID, 타임스탬프, sensorField1 및 sensorField2가 포함됩니다.

JOIN을 사용하는 추가 솔루션:

JOIN을 활용하는 대체 솔루션 작업:

SELECT
    s1.sensorID,
    s1.timestamp,
    s1.sensorField1,
    s1.sensorField2
FROM sensorTable AS s1
JOIN (
    SELECT sensorID, MAX(timestamp) AS max_timestamp
    FROM sensorTable
    GROUP BY sensorID
) AS s2
    ON s1.sensorID = s2.sensorID AND s1.timestamp = s2.max_timestamp;
  • 이 쿼리는 각 센서 ID에 대한 최대 타임스탬프를 포함하는 임시 테이블(s2)을 생성합니다.
  • s1(기본 테이블)은 센서 ID의 s2와 조인되며 타임스탬프 열을 사용하여 각 키 값에 대한 가장 최근 행을 선택합니다.

위 내용은 데이터베이스 테이블의 각 키에 대한 가장 최근 값을 효율적으로 선택하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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