>데이터 베이스 >MySQL 튜토리얼 >MAX() 및 GROUP BY를 사용하여 MySQL에서 각 RID의 최신 PID를 얻는 방법은 무엇입니까?

MAX() 및 GROUP BY를 사용하여 MySQL에서 각 RID의 최신 PID를 얻는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-30 02:02:09566검색

How to Get the Latest PID for Each RID in MySQL Using MAX() and GROUP BY?

MySQL 쿼리: MAX() GROUP BY

질문:

최신 행의 PID를 어떻게 검색합니까? MAX()와 GROUP을 결합하는 MySQL 쿼리를 사용하여 테이블의 각 RID에 대해 BY?

샘플 데이터:

CREATE TABLE theTable (
    `pid` INT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
    `timestamp` TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    `cost` INT UNSIGNED NOT NULL,
    `rid` INT NOT NULL,
) Engine=InnoDB;

INSERT INTO theTable (`pid`, `timestamp`, `cost`, `rid`)
VALUES
  (1, '2011-04-14 01:05:07', 1122, 1),
  (2, '2011-04-14 00:05:07', 2233, 1),
  (3, '2011-04-14 01:05:41', 4455, 2),
  (4, '2011-04-14 01:01:11', 5566, 2),
  (5, '2011-04-14 01:06:06', 345, 1),
  (6, '2011-04-13 22:06:06', 543, 2),
  (7, '2011-04-14 01:14:14', 5435, 3),
  (8, '2011-04-14 01:10:13', 6767, 3)
;

원하는 결과:

pid | MAX(timestamp)      | rid
-----------------------------------
5   | 2011-04-14 01:06:06 | 1
3   | 2011-04-14 01:05:41 | 2
7   | 2011-04-14 01:14:14 | 3

잘못됨 쿼리:

SELECT MAX(timestamp),rid,pid FROM theTable GROUP BY rid

이 쿼리는 최신 RID가 아닌 각 RID가 처음 나타나는 PID를 반환합니다.

올바른 쿼리:

각 RID에 대한 최신 행의 PID를 검색하려면 다음을 사용할 수 있습니다. 쿼리:

SELECT pid, MAX(timestamp) AS latest_timestamp, rid
FROM theTable
GROUP BY rid
HAVING latest_timestamp = MAX(timestamp)

이 쿼리는 먼저 GROUP BY 절을 사용하여 RID 열을 기준으로 행을 그룹화합니다. 그런 다음 MAX() 함수를 사용하여 각 행 그룹의 최대 타임스탬프를 계산합니다. 마지막으로 HAVING 절을 사용하여 결과를 필터링하여 각 RID에 대해 최신 타임스탬프가 있는 행만 유지합니다.

위 내용은 MAX() 및 GROUP BY를 사용하여 MySQL에서 각 RID의 최신 PID를 얻는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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