MySql语句执行顺序

Sql语句的执行顺序
例:SELECT `name`,COUNT(`name`) AS num FROM student WHERE grade < 60 GROUP BY `name` HAVING num >= 2 ORDER BY num DESC,`name` ASC LIMIT 0,2;

1、首先会执行from语句,把数据库的表文件加载到内存中。
2、执行where语句,根据筛选条件过滤出数据并且在内存中生成一张临时表。
3、如果有group by语句,会根据group by把内存中的临时表切割成多张临时表
4、执行select语句,如果语句中没有group by,则在临时表中执行select语句,若有group by语句,则会在多张临时表中分别执行select语句。
5、如果语句中有having关键字,则执行完select语句后执行having,对数据进行二次过滤,值得注意的是,执行where语句时,是不能用到字段别名的,因为执行where时,还没有执行select,所以这时是不能使用字段别名的,但是执行having时,是可以用字段别名的,因为having语句是在select语句执行之后执行的,所以可以用到字段别名。
6、当上述语句执行完成后,继续会执行order by语句,进行排序后执行limit分页语句,然后返回查询结果,结束当前sql语句的执行。

posted @   崔赫的博客  阅读(439)  评论(0编辑  收藏  举报
编辑推荐:
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
· 一次Java后端服务间歇性响应慢的问题排查记录
· dotnet 源代码生成器分析器入门
· ASP.NET Core 模型验证消息的本地化新姿势
· 对象命名为何需要避免'-er'和'-or'后缀
阅读排行:
· “你见过凌晨四点的洛杉矶吗?”--《我们为什么要睡觉》
· 编程神器Trae:当我用上后,才知道自己的创造力被低估了多少
· C# 从零开始使用Layui.Wpf库开发WPF客户端
· 开发的设计和重构,为开发效率服务
· 从零开始开发一个 MCP Server!
点击右上角即可分享
微信分享提示