我的表如下所示(我使用的是MySQL):
m_id | v_id | timestamp
------------------------
6 | 1 | 1333635317
34 | 1 | 1333635323
34 | 1 | 1333635336
6 | 1 | 1333635343
6 | 1 | 1333635349
我的目标是获取每个m_id一次,并按最高的时间戳排序。
结果应为:
m_id | v_id | timestamp
------------------------
6 | 1 | 1333635349
34 | 1 | 1333635336
我写了这个查询:
SELECT * FROM table GROUP BY m_id ORDER BY timestamp DESC
但是,结果是:
m_id | v_id | timestamp
------------------------
34 | 1 | 1333635323
6 | 1 | 1333635317
我认为这是因为它首先执行GROUP_BY,然后对结果进行排序。
有什么主意吗?谢谢。
8条答案
按热度按时间mo49yndu1#
正确使用
group by
的一种方法是:工作原理:
m_id
的最新时间戳table
中选择与子查询中的行匹配的行(这个操作--执行了连接,但没有从第二个表中选择列,它只是用作过滤器--如果您好奇的话,它被称为“半连接”)jum4pzuy2#
如果您真的不关心将获得哪个时间戳,并且对于给定的
m_i
,您的v_id
始终相同,则可以执行以下操作:现在,如果
v_id
对于给定的m_id
发生了变化,则应该执行以下操作xnifntxz3#
下面是最简单的解决方案
按m_id分组,但获取每个m_id的最大时间戳。
bcs8qyzn4#
你可以试试这个
1l5u6lss5#
SQL语言〉
ktecyv1j6#
刚开始我试着理解问题和答案时感到困惑,我花了一些时间阅读,我想做一个总结。
然后我又看了一下这个被接受的答案,我发现实际上OP是想表达这个问题的,比如一个样本表:
他想要选择仅基于**(
group by
)m_id
和(order by
)timestamp
的所有列。那么上面的sql就不能用了,如果你还是不明白,想象一下你的列数比
m_id | v_id | timestamp
多,比如m_id | v_id | timestamp| columnA | columnB |column C| ...
,使用group by
,你只能选择那些“group by”列,然后在结果中聚合函数。到目前为止,你应该已经明白了公认的答案,更重要的是,检查MySQL 8.0中引入的
row_number
函数:https://www.mysqltutorial.org/mysql-window-functions/mysql-row_number-function/
1.查找每个组的前N行
它所做的事情与公认的答案相似。
1.有些答案是错误的**。我的MySQL给我错误。
@阿比纳什萨胡
@维卡斯·加尔瓦尔
错误信息:
nukf8bse7#
为什么搞得这么复杂?这很有效。
xcitsw888#
你只需要使用ascdesc。编写如下的查询。它将以升序返回值。