MySQL:请问为什么在WHERE从句中不能使用聚集函数进行过滤?

我这边想找到分数最高的学生编号:SELECT 学号 FROM 学生表 WHERE 分数 = MAX(分数);
奈何这条语句无法执行,只能使用子查询。想请问一下,为什么 在WHERE从句中不能使用聚集函数进行过滤呀?我的猜想是因为MySQL执行WHERE会先于MAX函数,所以在过滤时,MAX函数还没有找到最大值以供过滤。请问是这样吗?谢谢~

select * from student order by score desc limit 1
也能完成你的工作。

无法执行是因为语法根本就不对,跟先执行后执行没有关系呀
你使用了max函数要作为select才能返回值,你直接写个max,那求的是什么东西的max呢,max没有from语句,你让它计算什么呢

sql语句执行顺序。
where筛选在所有聚合函数之前执行,这个过滤是最终的。
也就是where会生成一张虚拟表,而之后的group by、sum或者avg啥的,都是基于这张虚拟表操作了。