55

我的表看起来像这样(我正在使用 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 然后对结果进行排序。

有任何想法吗?谢谢你。

4

8 回答 8

65

一种正确使用的方法group by

select l.* 
from table l
inner join (
  select 
    m_id, max(timestamp) as latest 
  from table 
  group by m_id
) r
  on l.timestamp = r.latest and l.m_id = r.m_id
order by timestamp desc

这是如何工作的:

  • m_id选择子查询中每个不同的最新时间戳
  • 仅从与子查询中的行匹配的行中选择行table(此操作 - 执行连接,但未从第二个表中选择列,它仅用作过滤器 - 被称为“半连接”,以防您很好奇)
  • 对行进行排序
于 2012-04-05T14:48:04.213 回答
14

如果您真的不关心您将获得哪个时间戳,并且v_id对于给定的时间戳始终相同,m_i您可以执行以下操作:

select m_id, v_id, max(timestamp) from table
group by m_id, v_id
order by max(timestamp) desc

现在,如果v_id给定的更改,m_id那么您应该执行以下操作

select t1.* from table t1
left join table t2 on t1.m_id = t2.m_id and t1.timestamp < t2.timestamp
where t2.timestamp is null
order by t1.timestamp desc
于 2012-04-05T14:55:10.753 回答
6

这是最简单的解决方案

select m_id,v_id,max(timestamp) from table group by m_id;

按 m_id 分组,但获取每个 m_id 的最大时间戳。

于 2018-03-22T06:01:42.793 回答
5

你可以试试这个

 SELECT tbl.* FROM (SELECT * FROM table ORDER BY timestamp DESC) as tbl
 GROUP BY tbl.m_id  
于 2016-01-28T06:01:59.923 回答
4

SQL>

SELECT interview.qtrcode QTR, interview.companyname "Company Name", interview.division Division 
FROM interview 
JOIN jobsdev.employer 
    ON (interview.companyname = employer.companyname AND employer.zipcode like '100%')
GROUP BY interview.qtrcode, interview.companyname, interview.division
ORDER BY interview.qtrcode;
于 2015-05-18T02:03:33.713 回答
2

当我一开始试图理解问题和答案时,我感到很困惑。我花了一些时间阅读,我想做一个总结。

  1. OP的例子有点误导。起初我不明白为什么接受的答案是接受的答案。我认为OP的要求可以简单地满足
select m_id, v_id, max(timestamp) as max_time from table
group by m_id, v_id
order by max_time desc

然后我又看了一下接受的答案。而且我发现实际上OP想要表达这一点,例如:

m_id | v_id | timestamp
------------------------
6    |   1  | 11
34   |   2  | 12
34   |   3  | 13
6    |   4  | 14
6    |   5  | 15

他想基于( )和 ( )选择所有列group bym_idorder bytimestamp

那么上面的sql就不行了。如果您仍然不明白,请想象您的列数多于 m_id | v_id | timestamp, 例如m_id | v_id | timestamp| columnA | columnB |column C| .... 使用group by,您只能在结果中选择那些“分组依据”列和聚合函数。

到目前为止,您应该已经理解了公认的答案。row_number更重要的是, MySQL 8.0 中引入了检查功能:

https://www.mysqltutorial.org/mysql-window-functions/mysql-row_number-function/

  1. 查找每组的前 N ​​行

它的作用与公认的答案相似。

  1. 有些答案是错误的。我的 MySQL 给了我错误。
select m_id,v_id,max(timestamp) from table group by m_id;

@abinash sahoo

SELECT m_id,v_id,MAX(TIMESTAMP) AS TIME
 FROM table_name 
 GROUP BY m_id

@Vikas Garhwal

错误信息:

[42000][1055] Expression #2 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'testdb.test_table.v_id' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by
于 2021-11-05T08:36:44.967 回答
-2

只是你需要用 asc 来描述。编写如下查询。它将按升序返回值。

SELECT * FROM table GROUP BY m_id ORDER BY m_id asc;
于 2016-11-18T16:22:33.513 回答
-2

为什么搞得这么复杂?这行得通。

SELECT m_id,v_id,MAX(TIMESTAMP) AS TIME
 FROM table_name 
 GROUP BY m_id
于 2018-10-02T13:18:25.253 回答