分组查询 GROUP BY
GROUP BY{列名|表达式|position}[ASC|DESC],...[WITH ROLLUP]
select 专业名,count(*) as '学生数'from xsgroup by 专业名;+----------+--------+| 专业名 | 学生数 |+----------+--------+| 电子商务 | 3 || 通信工程 | 2 |+----------+--------+
ROLLUP方法
末尾添加 with rollup;可以在表格最下端添加汇总
-> select 专业名,count(*) as '学生数'-> from xs-> group by 专业名-> with rollup;+----------+--------+| 专业名 | 学生数 |+----------+--------+| 电子商务 | 3 || 通信工程 | 2 || NULL | 5 | #汇总+----------+--------+3 rows in set (0.35 sec)
HAVING方法
HAVING 子句和 WHERE 子句非常相似,HAVING 子句支持 WHERE 子句中所有的操作符和语法,但是两者存在几点差异:
- WHERE 子句主要用于过滤数据行,而 HAVING 子句主要用于过滤分组,即 HAVING 子句基于分组的聚合值而不是特定行的值来过滤数据,主要用来过滤分组。
- WHERE 子句不可以包含聚合函数,HAVING 子句中的条件可以包含聚合函数。
- HAVING 子句是在数据分组后进行过滤,WHERE 子句会在数据分组前进行过滤。WHERE 子句排除的行不包含在分组中,可能会影响 HAVING 子句基于这些值过滤掉的分组。
mysql> SELECT dept_id,GROUP_CONCAT(name) AS names-> FROM tb_students_info-> GROUP BY dept_id-> HAVING COUNT(name)>1; #仅显示人数大于一的分组信息+---------+---------------+| dept_id | names |+---------+---------------+| 1 | Dany,Jane,Jim || 2 | Henry,John || 3 | Green,Thomas || 4 | Susan,Tom |+---------+---------------+4 rows in set (0.07 sec)
