对比Excel学习SQL(5):分组和子查询

本文是对比Excel学习SQL系列的第5部分,介绍了如何使用group by进行数据分组,包括计数、求和及平均值计算,并通过having过滤分组结果。此外,还讲解了子查询的概念,如何在where中使用子查询以及不同表间的子查询应用,帮助读者掌握SQL的分组和子查询操作。
摘要由CSDN通过智能技术生成

今天这篇文章是对比Excel学习SQL系列的第5篇文章,之前3篇的传送门在这里:《计算字段》、《对行和列的操作》、《库/表/记录的增查删改》、《写给小白的SQL学习文章》。

本节内容要用到的数据表:成绩表(sc),学生基本信息表(student1)

一、分组

01 创建分组

group by 命令用来创建分组,分组其实相当好理解,就是Excel里的数据透视表,汇总方式为计数、求和或平均的功能,所以通常和聚合函数结合起来使用。

--语法
select 列,聚合函数 from 表 where子句 group by 列;

Group by 要放在where之后,order by 之前

 

Q1:统计每个学号(snum)下的人数

用到【group by + count】,对snum学号一列分组并计数,相当于Excel透视表中把snum拖到列标签,同时对snum计数,结果是一样的。

select snum, count(*) from sc group by snum;

 

同理,你可以试试对cnum和score分组计数是什么结果。

 

Q2:统计每个学号(snum)下的总成绩

【group by + sum】,结合sum函数,可以统计每个学号的总成绩,Excel里是对score求和。

select snum,sum(score) from sc group by snum;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

进击的可乐!

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值