sql报错SELECT list is not in GROUP BY clause and contains nonaggregated column

高频面经汇总:https://blog.csdn.net/qq_40262372/article/details/116075528

一、问题分析

其中错误的原因是说group by 哪一句中的select 的字段是不对的。

二、情景还原

dept_emp表:

salaries表:

我想去查询每个部门人员薪水,于是写下了这样的sql:

select 
de.dept_no ,s.salary
from
dept_emp de
left join
salaries s
on
de.emp_no = s.emp_no
group by
de.dept_no 

于是成功报错。

三、报错的原因

group by 与 select 使用的时候。  select只能去查询分组的聚合变量。

什么是聚合变量呢?

比如我们上面的sql是利用部门编号分组的。

因此我们的组别是部门,但是我们查询的salary是人员属性,不是部门的,因此属于非聚合字段。

要怎么才能成功呢?  用max(salary) 用上聚合函数,将非聚合字段成为聚合字段。 这样salary就是找出该部门的最大值。 就会附带部门的属性了!!!

执行如下sql:

select 
de.dept_no ,max(s.salary)
from
dept_emp de
left join
salaries s
on
de.emp_no = s.emp_no
group by
de.dept_no 

成功:

  • 7
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

万小猿

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

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

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

打赏作者

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

抵扣说明:

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

余额充值