【发布时间】:2014-01-16 21:57:54
【问题描述】:
我有一个表,我想为该表选择一个类别中的最新时间戳,该类别由表中特定列的值定义。
具体来说
SELECT *
FROM takelist
WHERE producer_name = 'sean'
AND bucket_id = '2CCEx15_1o'
结果
+-------------+---------------+------------+---------------------+
| takelist_id | producer_name | bucket_id | ts |
+-------------+---------------+------------+---------------------+
| 1 | sean | 2CCEx15_1o | 2013-10-07 18:29:00 |
| 4 | sean | 2CCEx15_1o | 2013-10-07 18:33:09 |
| 5 | sean | 2CCEx15_1o | 2013-10-07 18:33:38 |
| 27 | sean | 2CCEx15_1o | 2013-10-07 18:37:38 |
| 212 | sean | 2CCEx15_1o | 2013-10-14 18:36:05 |
| 236 | sean | 2CCEx15_1o | 2013-10-21 17:59:56 |
| 237 | sean | 2CCEx15_1o | 2013-10-21 18:00:55 |
| 281 | sean | 2CCEx15_1o | 2013-10-29 15:58:40 |
| 287 | sean | 2CCEx15_1o | 2013-10-29 19:24:15 |
| 330 | sean | 2CCEx15_1o | 2013-10-31 14:39:33 |
| 615 | sean | 2CCEx15_1o | 2013-12-16 22:46:59 |
| 616 | sean | 2CCEx15_1o | 2013-12-16 22:54:46 |
+-------------+---------------+------------+---------------------+
我想为名为 bucket_id 的列的每个唯一值选择一行,其中所选行具有最新的时间戳。
我已经根据之前对类似问题的回答尝试了以下方法,但一定有问题
SELECT takes.* FROM takelist as takes
INNER JOIN (
SELECT takelist_id, max(ts) max_ts, bucket_id
FROM takelist
WHERE producer_name='sean'
GROUP BY bucket_id
) latest_take
ON takes.takelist_id=latest_take.takelist_id
AND takes.ts=latest_take.max_ts
【问题讨论】:
-
您的子查询依赖于 MySQL 特定的行为,并且您的语句将导致大多数/所有其他 RDBMS 引发语法错误:您列出的列既不在
GROUP BY中也不是聚合函数(如MAX())。在 MySQL 中,takelist_id在这种情况下的内容本质上是“不确定的”——它在很大程度上取决于您定义的索引、正在执行的查询等,并且完全取决于优化器的心血来潮。在这种情况下没有保证特定行为的好方法,因此请尽量避免使用此“功能”。
标签: mysql sql select group-by groupwise-maximum