聚合函数
- count(col): 表示求指定列的总行数
- max(col): 表示求指定列的最大值
- min(col): 表示求指定列的最小值
- sum(col): 表示求指定列的和
- avg(col): 表示求指定列的平均值
例子:
-- 查询男生的总身高 select sum(height) from students where gender = 1; -- 平均身高 select sum(height) / count(*) from students where gender = 1;
分组查询
group by的使用
group by可用于单个字段分组,也可用于多个字段分组
-- 根据gender字段来分组 select gender from students group by gender; -- 根据name和gender字段进行分组 select name, gender from students group by name, gender;
group by + group_concat()的使用
group_concat(字段名): 统计每个分组指定字段的信息集合,每个信息之间使用逗号进行分割
-- 根据gender字段进行分组, 查询gender字段和分组的name字段信息 select gender,group_concat(name) from students group by gender;
group by + 聚合函数的使用
-- 统计不同性别的人的平均年龄 select gender,avg(age) from students group by gender; -- 统计不同性别的人的个数 select gender,count(*) from students group by gender;
group by + having的使用
having作用和where类似都是过滤数据的,但having是过滤分组数据的,只能用于group by
-- 根据gender字段进行分组,统计分组条数大于2的 select gender,count(*) from students group by gender having count(*)>2;
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;