SQL语句中,为什么group by能够提前"预知"select的别名?

学习Mysql时,遇到了一个很疑惑的地方,查询了资料最终找到了结果:

1.SQL的执行顺序

首先我们知道SQL的执行顺序是:

④ select ① from ② where ③ group by having ⑤ order by ⑥ limit

2.问题出现

group by 支持别名,当我们执行SQL语句:

sql 复制代码
SELECT gender AS xb, COUNT(id) FROM employee GROUP BY xb;

会出现一个很奇怪的现象,按照前面讲述的 SQL 执行顺序,这条 SQL 语句应该报语法错误啊,因为group by是在select之前执行的呀,怎么能提前"预知"别名,似乎有点解释不通了?

3.问题答案

查阅官方文档之后,我发现 having 子句其实是在 select 子句后运行的。也就是说 having 其实是拿着运行 select 后的虚拟表过滤的,而不是原来的表

GROUP BY 子句能够使用SELECT子句中定义的别名,是因为SQL数据库引擎在内部对查询的执行过程进行了优化。这种优化允许引擎在执行GROUP BY之前预先计算SELECT子句中的表达式,并将结果存储为别名。这样,即使在逻辑上GROUP BY应该在SELECT之前执行,引擎也能够识别并重用这些别名,而不是重新计算表达式。

这主要得益于mysql做的拓展,查阅官方文档之后,可以发现是因为 ONLY_FULL_GROUP_BY 这个参数导致的。

开启后(默认开启)
ONLY_FULL_GROUP_BY 是 MySQL 的一种严格 SQL 模式,开启后要求 select、HAVING 和 ORDER BY 中出现的每个非聚合字段,都必须在 GROUP BY 子句中声明,或者能被 GROUP BY 字段唯一决定,否则查询会被拒绝;但 HAVING 子句可以直接引用 select 里的别名。具体网址在下面,感兴趣的可以进一步阅读一下:

dev.mysql.com/doc/refman/...

相关推荐
CV艺术家14 分钟前
java原mysql切换国产达梦数据库
数据库·mysql
努力进修28 分钟前
【MySQL】90% 的 MySQL 性能问题都和它有关!索引的正确打开方式,看完少走 3 年弯路
数据库·mysql
0xDevNull9 小时前
MySQL数据冷热分离详解
后端·mysql
一江寒逸9 小时前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
D4c-lovetrain9 小时前
linux个人心得22 (mysql)
数据库·mysql
做个文艺程序员10 小时前
MySQL安全加固十大硬核操作
数据库·mysql·安全
MaCa .BaKa10 小时前
47-心里健康咨询平台/心理咨询系统
java·spring boot·mysql·tomcat·maven·intellij-idea·个人开发
一江寒逸10 小时前
零基础从入门到精通MySQL(上篇):筑基篇——吃透核心概念与基础操作,打通SQL入门第一关
数据库·sql·mysql
爱莉希雅&&&11 小时前
linux中MySQL数据库备份恢复的四种方法(更新中)
linux·数据库·mysql·数据库备份·mysqldumper
枕布响丸辣12 小时前
Python 操作 MySQL 数据库从入门到精通
数据库·python·mysql