使用ORDER BY和GROUP BY一起使用ORDER BY和GROUP BY一起(Using O

2019-05-13 10:56发布

我的表看起来像这样(我使用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  | 1333635343
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然后顺序排列结果。

有任何想法吗? 谢谢。

Answer 1:

这样做的一种方式,正确地使用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从子查询(该操作匹配的行-其中执行加入,但没有列被从第二表中选择,它只是作为一个过滤器-被称为一个“半连接”的情况下你是好奇)
  • 订单行


Answer 2:

如果你真的不关心哪些时间戳你会得到你的v_id始终是一个给定同样m_i你可以做到以下几点:

select m_id, v_id, max(timestamp) from table
group by m_id, v_id
order by 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


Answer 3:

你可以试试这个

 SELECT tbl.* FROM (SELECT * FROM table ORDER BY timestamp DESC) as tbl
 GROUP BY tbl.m_id  


Answer 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;


Answer 5:

这是最简单的解决方案

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

集团通过M_ID但得到的时间戳的最大值为每M_ID。



Answer 6:

只要你需要ASC来说明。 写像下面的查询。 它会按升序返回值。

SELECT * FROM table GROUP BY m_id ORDER BY m_id asc;


Answer 7:

为什么让这么复杂吗? 这个工作。

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


文章来源: Using ORDER BY and GROUP BY together