MySQL 쿼리, MAX() + GROUP BY
Daft SQL 질문입니다.저는 그런 테이블이 있습니다. ('pid'는 auto-increment primary col)
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)
;
각 RID(고유 RID당 1개의 결과)에 대한 최신 행의 PID를 받고 싶습니다.샘플 데이터의 경우 다음과 같이 하고 싶습니다.
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
알 수 있습니다.
max(timestamp) ; rid; pid
----------------------------
2011-04-14 01:06:06; 1 ; 1
2011-04-14 01:05:41; 2 ; 3
2011-04-14 01:14:14; 3 ; 7
반환되는 PID는 항상 RID의 첫 번째 PID입니다(행/pid 1은 RID 1이 처음 사용될 때, 행/pid 3은 RID 2가 처음 사용될 때, 행/pid 7은 RID 3이 처음 사용될 때).각 rid에 대한 최대 타임스탬프를 반환하지만 pid는 원래 테이블의 타임스탬프에 대한 pid가 아닙니다.어떤 쿼리를 사용하면 제가 찾고 있는 결과를 얻을 수 있습니까?
(Postgre에서 테스트됨)SQL 9.something)
제거 및 타임스탬프를 식별합니다.
select rid, max(timestamp) as ts
from test
group by rid;
1 2011-04-14 18:46:00
2 2011-04-14 14:59:00
함께 해요.
select test.pid, test.cost, test.timestamp, test.rid
from test
inner join
(select rid, max(timestamp) as ts
from test
group by rid) maxt
on (test.rid = maxt.rid and test.timestamp = maxt.ts)
select *
from (
select `pid`, `timestamp`, `cost`, `rid`
from theTable
order by `timestamp` desc
) as mynewtable
group by mynewtable.`rid`
order by mynewtable.`timestamp`
내가 도와줬기를!
SELECT t.pid, t.cost, to.timestamp, t.rid
FROM test as t
JOIN (
SELECT rid, max(tempstamp) AS maxtimestamp
FROM test GROUP BY rid
) AS tmax
ON t.pid = tmax.pid and t.timestamp = tmax.maxtimestamp
rid와 타임스탬프에 대한 인덱스를 만들었습니다.
SELECT test.pid, test.cost, test.timestamp, test.rid
FROM theTable AS test
LEFT JOIN theTable maxt
ON maxt.rid = test.rid
AND maxt.timestamp > test.timestamp
WHERE maxt.rid IS NULL
0 - 2 행 표시(총 3개, 쿼리에 0.0104초 소요)
이 메서드는 원하는 값을 모두 선택합니다.theTable
(test), 모든 타임스탬프에서 동일한 rid를 가진 테스트의 타임스탬프보다 높은 왼쪽 조인 자체(test).타임스탬프가 이미 테스트에서 가장 높은 타임스탬프일 때 max에서 일치하는 값이 없습니다(바로 우리가 찾고 있는 것입니다). 이제 우리는 WHERE 절을 사용합니다.maxt.rid IS NULL
또는 max에 있는 다른 열.
다음과 같은 하위 쿼리를 사용할 수도 있습니다.
SELECT ( SELECT MIN(t2.pid)
FROM test t2
WHERE t2.rid = t.rid
AND t2.timestamp = maxtimestamp
) AS pid
, MAX(t.timestamp) AS maxtimestamp
, t.rid
FROM test t
GROUP BY t.rid
하지만 이렇게 하면, 당신이 원한다면 서브쿼리가 하나 더 필요할 것입니다.cost
표시된 열 등에 포함됩니다.
그래서.group by
그리고.join
더 나은 해결책입니다.
JOIN을 피하려면 다음을 사용할 수 있습니다.
SELECT pid, rid FROM theTable t1 WHERE t1.pid IN ( SELECT MAX(t2.pid) FROM theTable t2 GROUP BY t2.rid);
시도:
select pid,cost, timestamp, rid from theTable order by timestamp DESC limit 2;
언급URL : https://stackoverflow.com/questions/5657446/mysql-query-max-group-by
'programing' 카테고리의 다른 글
워드프레스 후크 사전사후 업데이트 (0) | 2023.09.13 |
---|---|
mariadb가 localhost 사용자를 인식하지 못함 (0) | 2023.09.13 |
VBA, PDF를 하나의 PDF 파일로 결합 (0) | 2023.09.08 |
활동하지 않는 곳에 getLayoutInflater() 호출 (0) | 2023.09.08 |
MariaDB 루프가 쿼리 결과를 표시하지 않음 (0) | 2023.09.08 |