[英]Using ORDER BY and GROUP BY together
我的表看起来像这样(我正在使用 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,然后对结果进行排序。
有任何想法吗? 谢谢你。
一种正确使用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
中选择与子查询中的行匹配的行(此操作——执行连接,但未从第二个表中选择列,它仅用作过滤器——称为“半连接” ,以防万一你很好奇) 如果您真的不关心您将获得哪个时间戳并且您的v_id
对于给定的m_i
始终相同,您可以执行以下操作:
select m_id, v_id, max(timestamp) from table
group by m_id, v_id
order by max(timestamp) desc
现在,如果给定m_id
的v_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
这是最简单的解决方案
select m_id,v_id,max(timestamp) from table group by m_id;
按 m_id 分组,但获取每个 m_id 的最大时间戳。
你可以试试这个
SELECT tbl.* FROM (SELECT * FROM table ORDER BY timestamp DESC) as tbl
GROUP BY tbl.m_id
数据库>
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;
当我一开始试图理解问题和答案时,我感到很困惑。 花了一些时间阅读,想做一个总结。
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
他想要 select仅基于( group by
) m_id
和( order by
) timestamp
的所有列。
那么上面的sql就不行了。 如果你还是不明白,假设你有比m_id | v_id | timestamp
更多的列。 m_id | v_id | timestamp
m_id | v_id | timestamp
,例如m_id | v_id | timestamp| columnA | columnB |column C|...
m_id | v_id | timestamp| columnA | columnB |column C|...
m_id | v_id | timestamp| columnA | columnB |column C|...
使用group by
,您只能 select 结果中的那些“分组依据”列和聚合函数。
到目前为止,您应该已经理解了接受的答案。 更重要的是,检查MySQL 8.0中引入的row_number
function:
https://www.mysqltutorial.org/mysql-window-functions/mysql-row_number-function/
- 查找每个组的前 N 行
它做的事情与公认的答案相似。
select m_id,v_id,max(timestamp) from table group by m_id;
@abinash 萨胡
SELECT m_id,v_id,MAX(TIMESTAMP) AS TIME
FROM table_name
GROUP BY m_id
@维卡斯加瓦尔
错误信息:
[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
为什么搞得这么复杂? 这奏效了。
SELECT m_id,v_id,MAX(TIMESTAMP) AS TIME
FROM table_name
GROUP BY m_id
只需要用 asc 描述即可。 编写如下查询。 它将按升序返回值。
SELECT * FROM table GROUP BY m_id ORDER BY m_id asc;
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.