Mysql取分组后的每组第一条数据

Mysql取分组后的每组第一条数据
gruop by 分组后 进行 order by mysql会按照 先分组后排序的形式进行输出 并不能做到每组中的第一条数据取出。

我的思路是 : 先将要查询的数据表转换成已经排序的临时表 在进行 分组操作 。 因为在mysql分组是将第一个出现的数据进行展示出。

MySQL会创建临时表的几种情况:
1、UNION查询;
2、用到TEMPTABLE算法或者是UNION查询中的视图;
3、ORDER BY和GROUP BY的子句不一样时;
4、表连接中,ORDER BY的列不是驱动表中的;(指定了联接条件时,满足查询条件的记录行数少的表为[驱动表],未指定联接条件时,行数少的表为[驱动表],多表联合查询时)
5、DISTINCT查询并且加上ORDER BY时;
6、SQL中用到SQL_SMALL_RESULT选项时;
7、FROM中的子查询;
8、子查询或者semi-join时创建的表;

SQL :
select DISTINCT school,title,content,update_time FROM content gruop by school order by update_time DESC

这样就是把每组最新时间的一条数据查询出来了。

如果上面的不行可以试下:

select * from ( select DISTINCT school,title,content,update_time FROM content order by update_time DESC ) as a gruop by a.school

 

posted @ 2020-04-30 17:15  hejw  阅读(15831)  评论(1编辑  收藏  举报