我这边想找到分数最高的学生编号:SELECT 学号 FROM 学生表 WHERE 分数 = MAX(分数);
奈何这条语句无法执行,只能使用子查询。想请问一下,为什么 在WHERE从句中不能使用聚集函数进行过滤呀?我的猜想是因为MySQL执行WHERE会先于MAX函数,所以在过滤时,MAX函数还没有找到最大值以供过滤。请问是这样吗?谢谢~
![](https://profile-avatar.csdnimg.cn/d249cf688e6b4af9a62d0222de150dda_weixin_49585347.jpg!4)
MySQL:请问为什么在WHERE从句中不能使用聚集函数进行过滤?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
3条回答 默认 最新
- CSDN专家-Time 2022-02-11 10:25关注
select * from student order by score desc limit 1
也能完成你的工作。解决 无用评论 打赏 举报