SQL 分组统计

这里以下列‘廖雪峰的官方网站’在线SQL地址测试

https://www.liaoxuefeng.com/wiki/1177760294764384/1179611432985088
搜索后的原始数据源
在这里插入图片描述

  • 原本想按gender进行二次分组,但发现分组后,统计的count(*),不是class_id下gender的去重的总数,而是以class_id,gender确认后组数的数量
SELECT class_id,gender,COUNT(*) AS number FROM students GROUP BY class_id,gender

在这里插入图片描述

  • 与上图对比发现,count(*) 统计的是gender二次分组后,组内的列数
    在这里插入图片描述

  • 解决方案一:

SELECT class_id,Count(distinct gender) as gender FROM students group by class_id;
  • 下图为理想效果,在不跨表的情况下
    在这里插入图片描述
  • 解决方案二:
    先分组到临时表,在查询临时列分组
SELECT class_id,count(*) as number FROM 
(SELECT class_id,gender as number FROM students Group by class_id,gender)
 group by class_id

补充说明:分组统计取前20条,可用于排行或者查询违规类统计

SELECT TOP 20 class_id,Count(distinct gender) as gender FROM students group by class_id Order by gender desc;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值