SQL查询语句执行顺序
Posted HuZihu
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL查询语句执行顺序相关的知识,希望对你有一定的参考价值。
在大多数编程语言中,代码是按照编码顺序执行的,但是在SQL语言中,尽管SELECT语句第一个出现,但却不是第一个被执行的。
SQL查询语句内部执行顺序:
from子句--->where子句--->group by子句--->聚合函数--->having子句--->select 字段--->order by子句
每个执行步骤都会产生一个虚拟表,该虚拟表作为下一个步骤的输入。这些虚拟表对调用者(客户端应用程序或者外部查询)不可用。只有在最后一步生成的表才会返回给调用者。
SQL查询语句的完整结构如下,执行顺序为括号内数字:
(8) SELECT (9) DISTINCT <select_list>, (6) AGG_FUNC <select_list>
(1) FROM <left_table>
(3) <join_type> JOIN <right_table>
(2) ON <join_condition>
(4) WHERE <where_condition>
(5) GROUP BY <group_by_list>
(7) HAVING <having_condition>
(10) ORDER BY <order_by_list>
(1) FROM <left_table>
(3) <join_type> JOIN <right_table>
(2) ON <join_condition>
(4) WHERE <where_condition>
(5) GROUP BY <group_by_list>
(7) HAVING <having_condition>
(10) ORDER BY <order_by_list>
(11) LIMIT <limit_number> OFFSET <offset_number>
注:如有普通子查询,先执行普通子查询。
以上是关于SQL查询语句执行顺序的主要内容,如果未能解决你的问题,请参考以下文章
sql语句的执行顺序是啥,为啥下面这两个sql执行的结果是一样的