MySQLクエリMAX関数+GROUP BYのエラー

1540 ワード

まず、pidがプライマリ・キーであり、自動的に増加するテーブルを作成します.
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

すなわち、ridごとに作成時間が最も遅いデータを検索したい
以下のsqlを使用しました.
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

結果は明らかに間違っている
正しいSQLは次のとおりです.
select  theTable.pid,theTable.cost,theTable.timestamp,theTable.rid

from theTable INNER JOIN 
  (select rid,max(timestamp) as ts from theTable GROUP BY rid)

maxt on (theTable.rid = maxt.rid and theTable.timestamp = maxt.ts);