这条SQL语句为什么没有出错

这条SQL语句为什么没有出错

下面这条语句中的t.dname,和t.deptno并没有出现在GROUP BY 子句中,为何没有出现错误,前面不是说SELECT子句中可以包括聚合函数,或者GROUP BY子句的分组列,其余内容均不可以出现在SELECT子句中吗?

SELECT t.dname,t.deptno,COUNT(e.deptno)
FROM  t_dept t LEFT JOIN t_emp e ON e.deptno=t.deptno
GROUP BY t.deptno;


正在回答 回答被采纳积分+1

登陆购买课程后可参与讨论,去登陆

1回答
好帮手慕小蓝 2023-07-24 10:42:00

同学你好,其他内容出现在select语句中时,是不会报错的,但是由于其他字段的内容是多条的,整合到单条结果中进行展示时,该字段的数据内容可能会不正确,所以在规定时不允许这么做。

这个规定是为了避免上面的错误,而不是Mysql的语法检查,同学可以试一下课程案例中下面的sql语句,其结果中sal字段的值是不正确的。

select deptno , count(*) , avg(sal) ,sal  
from t_emp group by deptno;

祝学习愉快~

问题已解决,确定采纳
还有疑问,暂不采纳

恭喜解决一个难题,获得1积分~

来为老师/同学的回答评分吧

0 星
Java工程师 2024版
  • 参与学习       2052    人
  • 提交作业       1500    份
  • 解答问题       1324    个

2024重磅革新,超百小时内容豪华升级,加速提升高级技能与高薪就业竞争力 课程紧贴企业最新人才需求,历经7年持续迭代,帮助万名学子入行转行 从零起点到高阶实战,学习路径稳健顺滑,成就从小白到工程师高薪

了解课程
请稍等 ...
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号

在线咨询

领取优惠

免费试听

领取大纲

扫描二维码,添加
你的专属老师