少年陈永仁.R.GT( : 2022-02-11 10:21 采纳率: 0%
浏览 60

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

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

  • 写回答

3条回答 默认 最新

  • CSDN专家-Time 2022-02-11 10:25
    关注

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

    评论

报告相同问题?

问题事件

  • 创建了问题 2月11日

悬赏问题

  • ¥20 pip2.40更新pip2.43时报错
  • ¥15 换yum源但仍然用不了httpd
  • ¥50 C# 使用DEVMOD设置打印机首选项
  • ¥15 麒麟V10 arm安装gdal
  • ¥15 想用@vueuse 把项目动态改成深色主题,localStorge里面的vueuse-color-scheme一开始就给我改成了dark,不知道什么原因(相关搜索:背景颜色)
  • ¥20 OPENVPN连接问题
  • ¥15 flask实现搜索框访问数据库
  • ¥15 mrk3399刷完安卓11后投屏调试只能显示一个设备
  • ¥100 如何用js写一个游戏云存档
  • ¥15 ansys fluent计算闪退