집 >데이터 베이스 >MySQL 튜토리얼 >데이터베이스 테이블의 각 키에 대한 가장 최근 값을 효율적으로 선택하는 방법은 무엇입니까?
데이터베이스 테이블의 각 키에 대해 가장 최근 값 선택
센서 데이터 또는 기타 타임스탬프 정보가 포함된 테이블로 작업할 때 각 개별 키 값에 대한 최신 항목을 검색하는 데 필요한 경우가 많습니다. 키를 기준으로 그룹화하고 최대 타임스탬프를 기준으로 정렬하는 간단한 접근 방식은 직관적으로 보일 수 있지만 집계에 키가 아닌 필드가 포함되어 오류가 발생할 수 있습니다.
하위 쿼리를 사용하는 대체 솔루션 :
각 키의 최대 타임스탬프를 식별하는 하위 쿼리를 사용하여 이 문제를 해결하는 한 가지 신뢰할 수 있는 방법 값:
SELECT sensorID, timestamp, sensorField1, sensorField2 FROM sensorTable WHERE timestamp = (SELECT MAX(timestamp) FROM sensorTable WHERE sensorID = sensorTable.sensorID) ORDER BY sensorID, timestamp;
이 쿼리에서:
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;
위 내용은 데이터베이스 테이블의 각 키에 대한 가장 최근 값을 효율적으로 선택하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!