mysql之group by,order by

写在前面

上篇文章介绍mysql的增删改查操作,这篇将介绍group和order by操作。

系列文章

mysql之创建数据库,创建数据表

mysql之select,insert,delete,update

一个例子

group by

顾名思义,是按照哪个字段分组,比如按照名字分组,则是所有名字相同的分为一组。在一些计数及求和中用到最多。

还以上篇文章的学生信息表为例。

1.求出每个年龄阶段的学生的个数。

use school;
-- 求出每个年龄阶段的学生个数
select * from tb_student;
select age,count(age) from tb_student group by Age;

分组结果

由上面的tb_student表可以看出,23岁的学生有两名,而其他年龄阶段的各有一名。

在分组的时候,你可以输出计数结果,但如果你如果想输出其他的信息,比如输出名字,这样做是没有意义的。因为只会输出一个,例如:

select `name`,age,count(age) from tb_student group by Age;

虽然没有报错,但是这样的统计,并不能让人信服。因为23岁的学生有两名:麻子和孙悟空。

所以,group by大都和聚合函数配合函数一起使用,聚合聚合,顾名思义就是,将多个结果合成一个结果,比如计数,求和,平均数等函数。

那如果真的要输出所有23岁的名字的话,那么可以这样:

MySQL group_concat函数
完整的语法如下:
group_concat([DISTINCT] 要连接的字段 [Order BY ASC/DESC 排序字段] [Separator '分隔符'])

这个函数,可以将分组后拼接内容,也算一个聚合函数,将多个结果拼接成一个结果,也可以拼接的同时进行结果去重。

select group_concat(`name`,',') as stuName,age,count(age) as AgeCount from tb_student group by Age ;

将想要的统计内容,分组拼接:

有上面的结果,也可以看出23岁的学生有两名,分别为麻子,孙悟空。这样统计的结果更具有说服力。

ordery by

按哪个字段进行排序,默认升序,desc降序。

接着在上个例子中按照统计的人数进行降序排列

use school;
select group_concat(`name`,',') as stuName,age,count(age) as AgeCount from tb_student group by Age order by count(age) desc;

排序比较好理解,这里就介绍到这里。

总结

这篇介绍了分组和排序的内容,在做统计的时候非常有用。

 

博客地址: http://www.cnblogs.com/wolf-sun/
博客版权: 本文以学习、研究和分享为主,欢迎转载,但必须在文章页面明显位置给出原文连接。
如果文中有不妥或者错误的地方还望高手的你指出,以免误人子弟。如果觉得本文对你有所帮助不如【推荐】一下!如果你有更好的建议,不如留言一起讨论,共同进步!
再次感谢您耐心的读完本篇文章。http://www.cnblogs.com/wolf-sun/p/4507590.html
时间: 2024-10-31 19:52:19

mysql之group by,order by的相关文章

MySQL · 捉虫动态 · ORDER/GROUP BY 导致 mysqld crash

问题描述 表结构如下所示: show create table test\G Table: test Create Table: CREATE TABLE `test` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT, `id2` varchar(50) DEFAULT NULL `id3` varchar(100) DEFAULT NULL `some_text` varchar(200) DEFAULT NULL `name` varchar(

mysql使用GROUP BY分组实现取前N条记录的方法_Mysql

本文实例讲述了mysql使用GROUP BY分组实现取前N条记录的方法.分享给大家供大家参考,具体如下: MySQL中GROUP BY分组取前N条记录实现 mysql分组,取记录 GROUP BY之后如何取每组的前两位下面我来讲述mysql中GROUP BY分组取前N条记录实现方法. 这是测试表(也不知道怎么想的,当时表名直接敲了个aa,汗~~~~): 结果: 方法一: 复制代码 代码如下: SELECT a.id,a.SName,a.ClsNo,a.Score FROM aa a LEFT J

mysql 分组group by排序取每条记录中,时间最大的一条记录

mysql 分组 group by, 排序 取每条记录中,时间最大的一条记录 以下是 test 表,测试sql CREATE TABLE IF NOT EXISTS `test` ( `id` int(10) unsigned NOT NULL auto_increment, `install` int(10) unsigned NOT NULL, `day` int(10) unsigned NOT NULL, `aid` int(10) unsigned NOT NULL, PRIMARY

mysql优化-急急急!!mysql,查询中ORDER BY A,B,C DESC 太慢,如何优化??

问题描述 急急急!!mysql,查询中ORDER BY A,B,C DESC 太慢,如何优化?? 急急急!!mysql,查询中ORDER BY A,B,C DESC 太慢,如何优化??急急急!!mysql,查询中ORDER BY A,B,C DESC 太慢,如何优化?? 查询50万条数据,慢死了 解决方案 建立A,B,C的联合索引 解决方案二: 在ABC上建立索引 select * from 表 where id between 0 and (select max(id) from 表) ord

mysql中group by留下的数据是哪一条

问题描述 mysql中group by留下的数据是哪一条 group by分组后,会留下一条数据,请问留下的这条数据,我们可以指定吗?就是指定显示出来的那条数据是某组中的指定的某条数据. 解决方案 你可以group生成到i一个表中,然后你再select where加条件把你需要的查询出来 解决方案二: 你可以在group by 后面用having的,having是专门用来处理分组后的数据的,包括就显示一条数据 解决方案三: 留下的数据是它默认排序的第一条. 如果要这么做那可以把group by的

mysql中Group By 如何统计

问题描述 mysql中Group By 如何统计 数据如下: 访问时间 离开时间 2014-1-1 2014-1-2 2014-1-3 2014-2-1 2014-2-2 2014-2-8 2014-2-8 2014-3-1 2014-3-5 2014-3-5 2014-3-5 2014-4-1 2014-4-1 2014-4-10 2014-4-2 请问如何用sql计算分组显示,2-3月区间的数据 时间 ---- 访问次数 ---离开次数 2013-2 ----- 3 ----- 1 2013

mysql获取group by的总记录行数另类方法_Mysql

mysql获取group by内部可以获取到某字段的记录分组统计总数,而无法统计出分组的记录数. mysql的SQL_CALC_FOUND_ROWS 使用 获取查询的行数 在很多分页的程序中都这样写: 代码如下 SELECT COUNT(*) from `table` WHERE ......; 查出符合条件的记录总数 代码如下 SELECT * FROM `table` WHERE ...... limit M,N; 查询当页要显示的数据 这样的语句可以改成: 代码如下 SELECT SQL_

mysql中group by与having合用注意事项分享_Mysql

group by函数应该的使用应该是SELECT 列表中指定的每一列也必须出现在 GROUP BY 子句中,除非这列是用于聚合函数,但是今天帮同事调试一个mysql中的group by函数,让我大跌眼镜,当时感觉不可思议,然后回来做了个简化版试验,试验过程如下: mysql表结构 复制代码 代码如下: mysql> desc t;+---+----–+--+-–+---+---+| Field | Type | Null | Key | Default | Extra |+---+----–+-

MySQL优化GROUP BY方案_Mysql

执行GROUP BY子句的最一般的方法:先扫描整个表,然后创建一个新的临时表,表中每个组的所有行应为连续的,最后使用该临时表来找到组并应用聚集函数(如果有聚集函数).在某些情况中,MySQL通过访问索引就可以得到结果,而不用创建临时表.此类查询的 EXPLAIN 输出显示 Extra列的值为 Using index for group-by. 一. 松散索引扫描 1.满足条件   查询针对一个表.  GROUP BY 使用索引的最左前缀.  只可以使用MIN()和MAX()聚集函数,并且它们均指