分组(group by)一般与聚合结合使用
(1)查询按性别分组
select gender from students group by gender;
(2)查询按性别分组并统计每组的数量
select gender,count(*) from students group by gender;
(3)查询按性别分组并统计每组的最大年龄
select gender,max(age) from students group by gender;
(4)查询男性的总数
select count(*) from students where gender=1;
(5)查询男性的总数(不推荐使用,不是标准的SQL语句)
select gender,count(*) from students where gender=1;
(6)查询男性的性别字段
select gender from students where gender=1;
(7)查询男性的总数(推荐,标准SQL语句,group by 以性别分组 ,其中性别才是每组的label)
select gender,count(*) from students where gender=1 group by gender;
(
group_concat()用于描述每个分组内成员的信息;
having位于group by之后,后面是限定每个分组的条件,这些条件将以每个组看作单个元素,所以条件采用聚合函数.
注意区分having与where,虽然两者后面都跟限定条件,但是限定的元素却不同
)
(8)查询分组后每组平均年龄大于15的组别并输出每组成员的姓名,年龄,ID及其平均年龄;
select gender,group_concat(name,‘ ‘,age,‘ ‘,ID),avg(age) from students group by gender having avg(age)>15;
(9)查询分组后每组平均年龄大于15的组别并输出每组成员的姓名,年龄,ID及其平均年龄;
select gender,group_concat(name,‘ ‘,age,‘ ‘,ID) from students group by gender having count(*)>2;
16-Mysql-Ubuntu-数据表的查询-分组与聚合(五)
原文:https://www.cnblogs.com/summer1019/p/11033183.html