数据库专题 SQL积累--group by学后自己的理解

本文深入探讨了SQL中的GROUP BY语句,解释了如何通过它对数据进行分类和聚合。GROUP BY用于根据一个或多个字段对数据进行分组,允许使用COUNT()和SUM()等聚合函数。举例来说,你可以通过GROUP BY name和number对test表进行分组,展示name和number,但不能包含未分组的id字段。这个概念在数据库管理和数据分析中至关重要。
摘要由CSDN通过智能技术生成

首先建表如下
在这里插入图片描述
执行SELECT name FROM test GROUP BY name

结果:

-----
Name
-----
aa
bb
cc
dd
ee

为了便于理解在上面两个表之间加一个虚拟过度表

在这里插入图片描述
相当于先对数据做一次分类,然后给出最后结果

但是

若直接执行select * 反而会报错,因为当个单元格中不允许有多个内内容存在,会导致关系混乱

简单来说 group by的最终结果只能从group by后面的字段中选择展示

若要累计可以使用count(id)和sum (number)
count()统计记录数 同列
sum() 做求和操作,对同列内容求和

Gourp by 多个字段时,可以把多个字段看成一个整体进行分组,需要同时满足多个一致的条件进行分组
若以group by name,number 则可以这样理解

见下图:
在这里插入图片描述
如此 select 中便可以加入 name,number
但 id依旧不可以加入

如:
SELECT name,number FROM test GROUP BY name,number

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值