【发布时间】:2011-08-05 04:09:42
【问题描述】:
愚蠢的 SQL 问题。我有一个这样的表('pid' 是自动递增的主要 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 的最新行的 PID(每个唯一 RID 1 个结果)。对于示例数据,我想:
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,row/pid 3 是第一次使用 RID 2,row/pid 7 是第一次使用 rid 3用来)。虽然返回每个消除的最大时间戳,但 pid 不是原始表中时间戳的 pid。什么查询会给我正在寻找的结果?
【问题讨论】:
-
你能显示你正在运行的确切查询的结果吗?
-
正确的sample code(此处为 SQL 语句)比任何即席模式和示例数据格式都更有用。样品请使用
CREATE TABLE和INSERT ... VALUES。所需的结果不需要以示例代码的形式呈现,因为结果是代码的输出,而不是代码本身。
标签: mysql sql database relational-database