Daft SQL問題。我有一個像這樣的表(「PID」是自動增量主要COL)MySQL查詢,MAX()+ GROUP 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爲每個RID(1每個唯一RID的結果)。對於樣本數據,我想:
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返回總是在第一次發生PID的RID(行/ pid 1是第一次使用rid 1,row/pid 3是第一次使用RID 2,row/pid 7是第一次使用rid 3)。雖然返回每個rid的最大時間戳,但pid不是來自原始表的時間戳的pid。什麼查詢會給我我要找的結果?
你可以告訴你正在運行的精確查詢的結果? – 2011-04-14 01:09:22
更新了問題:) – codinghands 2011-04-14 01:37:00
可能重複的[獲取具有列的最大值的行](http://stackoverflow.com/questions/121387/fetch-the-row-which-has-the-max-值爲列) – outis 2011-12-23 02:33:51