愚蠢的SQL问题.我有一个这样的表(‘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)
;

我想要获取每个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

我try 运行以下查询:

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

对于RID,返回的PID总是第一次出现PID(第一次使用ROW/PID 1时使用RID 1,第一次使用RID 2时返回ROW/PID 3,第一次使用RID3时返回ROW/PID 7).虽然返回每个RID的最大时间戳,但是PID不是来自原始表的时间戳的PID.哪个查询会给出我想要的结果?

推荐答案

(在PostgreSQL 9.something中测试)

标识RID和时间戳.

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)

Database相关问答推荐

为多个列 Select 最新的非空值

如何替换对象数组内的数组元素

第一次请求后数据库连接关闭

如何使用用户定义的字符串索引数据框?

将数据集上传到 Hub 时停止运行时会导致什么?

数据库约束 - 保留(keep)还是忽略(ignore)?

在 SQL Server 中找出调用存储过程

使用python为组中的每个元素添加一个序列号

SQL Select 用字符串替换整数

免费的 SQL 比较工具

数据库内部—从哪里开始?

为什么 DynamoDB 查询中没有**not equal**比较?

如何在sqlite数据库中添加日期

使用 java 查询 MySQL 数据库

为什么 MySQL 连接被许多连接错误阻止?

什么是数据仓库?

MySQL 整数 0 与 NULL

数据库与平面文本文件:当性能不是问题时, Select 一个而不是另一个的一些技术原因是什么?

最佳事件采购数据库策略

位图索引有何帮助?