深度理解 group by

为什么不能使用 select * from tb group by id

数据表:
在这里插入图片描述

SELECT name 
FROM tb
GROUP BY name

生成结果:
image.png

过程分析:
image.png

总结:

  • 如果执行select的话,那么返回的结果应该是虚拟表3,可是id和number中有的单元格里面的内容是多个值(个人理解:mysql会认为除了 group by后面跟的条件之外的其他列都是多个值,这里就是除了name 列)),而关系数据库就是基于关系的,单元格中是不允许有多个值的,所以,执行select * 语句就报错了**
  • 对于name列,每个单元格只有一个数据,所以我们select name的话,就没有问题了。(符合我的看法)
  • 所以对于其他列我们需要使用聚合函数,哪怕我们已知数据本身只有一个
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值