MySQL数据库分组查询group by(having)

1. 分组查询介绍

        分组查询就是将查询结果按照指定字段进行分组,字段中数据相等的分为一组。

分组查询基本的语法格式如下:

GROUP BY 列名 [HAVING 条件表达式] [WITH ROLLUP]

说明:

  • 列名: 是指按照指定字段的值进行分组。
  • HAVING 条件表达式: 用来过滤分组后的数据。   【分组过滤不用where】
  • WITH ROLLUP:在所有记录的最后加上一条记录,显示select查询时聚合函数的统计和计算结果

2. group by的使用

group by可用于单个字段分组,也可用于多个字段分组

-- 根据gender字段来分组
select gender from students group by gender;    等价 select distinct gender from students;
-- 根据name和gender字段进行分组
select name, gender from students group by name, gender;   【如果指定了分组字段,那么查询的时候只能使用指定分组字段】

 3. group by + group_concat()的使用

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;

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: MySQL数据库可以使用`GROUP BY`语句来进行分组查询。例如,如果你想按照顾客的国家分组查询订单总额,你可以使用以下查询: ``` SELECT customer_country, SUM(order_total) FROM orders GROUP BY customer_country; ``` 这会返回每个国家的订单总额,并将这些订单按照国家分组。 你还可以使用`HAVING`子句来筛选分组,例如,如果你想查询订单总额大于1000美元的国家,你可以使用以下查询: ``` SELECT customer_country, SUM(order_total) FROM orders GROUP BY customer_country HAVING SUM(order_total) > 1000; ``` 这会返回订单总额大于1000美元的国家及其订单总额。 希望这能帮助你! ### 回答2: MySQL数据库分组查询是指通过使用GROUP BY关键字将数据按照指定的列进行分组,并对每个分组进行聚合计算。下面是分组查询的基本语法: SELECT 列1, 列2, ... FROM 表名 GROUP BY 列1, 列2, ... HAVING 条件; 其中,列1, 列2, ...表示要查询的列名;表名表示要查询的数据表;列1, 列2, ...表示要进行分组的列;条件是对分组结果进行筛选的条件。 例如,我们有一个学生成绩表score,包含学生姓名(name)、科目(subject)和成绩(score)三个列。现在需要按照科目进行分组,计算每个科目的平均分,并筛选出平均分大于80的科目。 查询语句如下: SELECT subject, AVG(score) AS average_score FROM score GROUP BY subject HAVING average_score > 80; 在这个例子中,我们选择了科目列和使用AVG函数计算平均分,使用GROUP BY关键字按照科目进行分组,然后使用HAVING条件筛选出平均分大于80的科目。最终的查询结果为每个科目的平均分。 需要注意的是,在使用GROUP BY进行分组查询时,查询的列必须要么出现在GROUP BY子句中,要么出现在聚合函数中。否则,MySQL会报错。同时,HAVING条件用于筛选分组结果,只有满足该条件的分组才会被返回。 通过分组查询,我们可以方便地对数据进行分类统计和汇总分析,提供更有价值的信息。 ### 回答3: MySQL数据库分组查询可以使用GROUP BY子句来实现。GROUP BY子句将查询的结果按照指定的列进行分组,并根据每个组进行数据聚合计算。 基本语法如下: SELECT 列名1, 列名2, ... FROM 表名 GROUP BY 列名1, 列名2, ... 例如,假设有一个名为"students"的表,包含学生的姓名和年龄两列。我们希望统计每个年龄段的学生人数,可以使用以下查询语句: SELECT 年龄, COUNT(*) AS 人数 FROM students GROUP BY 年龄 以上查询会按照年龄分组,并统计每个年龄组的学生人数。使用COUNT(*)函数可以计算每个分组中的记录数。 若希望在分组的基础上,进一步筛选满足条件的结果,可使用HAVING子句。HAVING子句的使用方式与WHERE子句类似,区别在于WHERE子句用于过滤记录,而HAVING子句用于过滤分组。 例如,查询年龄大于等于18岁,并且人数超过10人的年龄段: SELECT 年龄, COUNT(*) AS 人数 FROM students GROUP BY 年龄 HAVING 年龄 >= 18 AND COUNT(*) > 10 以上查询会先按年龄分组,然后筛选出年龄大于等于18岁且人数超过10人的结果。 使用GROUP BY子句可以对查询结果进行分组计算,从而方便进行统计和分析。在实际应用中,我们可以根据具体需求灵活运用分组查询来满足不同的数据分析需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值