在线客服
扫描二维码
下载博学谷APP
扫描二维码
关注博学谷微信公众号
Group by分组查询怎么用?需要掌握哪些内容?groub by分组将查询结果按照1个或多个字段进行分组,字段值相同的为一组,可用于单个字段分组也可用于多个字段分组。

学习目标:能够写出分组查询的SQL语句。
1. 分组查询是什么?
分组查询就是将查询结果按照指定字段进行分组,字段中数据相等的分为一组。分组查询基本的语法格式如下:
GROUP BY 列名 [HAVING 条件表达式] [WITH ROLLUP]
说明:
(1)列名: 是指按照指定字段的值进行分组。
(2)HAVING 条件表达式: 用来过滤分组后的数据。
(3)WITH ROLLUP:在所有记录的最后加上一条记录,显示select查询时聚合函数的统计和计算结果
2. group by的怎么使用?
group by可用于单个字段分组,也可用于多个字段分组:
-- 根据gender字段来分组
select gender from students group by gender;
-- 根据name和gender字段进行分组
select name, gender from students group by name, gender;
3. group by + group_concat()的使用
-- 根据gender字段进行分组, 查询gender字段和分组的name字段信息
select gender,group_concat(name) from students group by gender;
4. group by + 聚合函数的使用
-- 统计不同性别的人的平均年龄
select gender,avg(age) from students group by gender;
-- 统计不同性别的人的个数
select gender,count(*) from students group by gender;
5. group by + having的使用
having作用和where类似都是过滤数据的,但having是过滤分组数据的,只能用于group by
-- 根据gender字段进行分组,统计分组条数大于2的
select gender,count(*) from students group by gender having count(*)>2;
6. group by + with rollup的使用
with rollup的作用是:在最后记录后面新增一行,显示select查询时聚合函数的统计和计算结果
-- 根据gender字段进行分组,汇总总人数
select gender,count(*) from students group by gender with rollup;
-- 根据gender字段进行分组,汇总所有人的年龄
select gender,group_concat(age) from students group by gender with rollup;
7. 小结
group by 根据指定的一个或者多个字段对数据进行分组;
group_concat(字段名)函数是统计每个分组指定字段的信息集合;
聚合函数在和 group by 结合使用时, 聚合函数统计和计算的是每个分组的数据;
having 是对分组数据进行条件过滤;
with rollup在最后记录后面新增一行,显示select查询时聚合函数的统计和计算结果;
— 申请免费试学名额 —
在职想转行提升,担心学不会?根据个人情况规划学习路线,闯关式自适应学习模式保证学习效果
讲师一对一辅导,在线答疑解惑,指导就业!
相关推荐 更多
零基础学习Python秘籍
Python是一门应用极其广泛的编程语言,现在从中小学到高等教育都开始普及Python技术。越来越多零基础的同学想要紧跟时代潮流,开始学习Python。对于零基础的同学如何快速学习Python呢?
6502
2019-11-27 18:27:26
Python基础知识学习框架梳理
对于编程初学者来说,在刚刚开始学习Python语言的时候,需要学习的内容有不少,比如计算机原理、网络、Web前端、后端、架构、 数据库都是必须掌握的知识点。因此初学者常常会陷入“只见树木,不见森林”的学习误区。本文为了帮助大家可以更好更快的掌握Python语言,特别为大家整理了Python基础知识的学习框架,有需要的小伙伴现在就来一起梳理下吧!
6620
2020-02-05 20:56:41
Python有哪些应用?学完Python能做什么工作?
Python编程语言仅次于Java和C语言,占据排行榜第三的位置。Python被越来越多的企业以及编程工作者采用。那Python都有哪些应用,学习完成Python后能从事哪些方面的工作呢?
7781
2020-05-15 17:44:04
Python零基础入学课程学什么?
如果你没有具备任何一门语言的面向对象知识,是完完全全的编程小白,那么博学谷的Python零基础入学课程将带你快速上手Python的基础入门知识。学习该套入学课程,你将掌握 Python入门语法所需要的一切知识点,为将来的深入学习Python打下坚实的基础。下面我们来看看Python零基础入学课程的具体学习内容。
5943
2020-06-22 18:42:35
Python小学生课程学哪些内容?
Python小学生课程学习主要是以入门为主,工业界学习Python,现在中学生已经开始学习Python且是必修课,入学的高中生需要学习Python语言。简单易学的编程语言Python进入小学教材,更会纳入高考内容体系。
9538
2020-08-07 14:29:38
