mysql group by max_MySQL查询,MAX()+ GROUP BY?mysql-问答-阿里云开发者社区-阿里云

愚蠢的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 我尝试运行以下查询:

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。什么查询可以给我我想要的结果?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值