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>
(11) LIMIT <limit_number> OFFSET <offset_number>
 
注:如有普通子查询,先执行普通子查询。

 

以上是关于SQL查询语句执行顺序的主要内容,如果未能解决你的问题,请参考以下文章

sql语句的执行顺序是啥,为啥下面这两个sql执行的结果是一样的

关于SQL语句的执行先后顺序,希望高手解答并写出原因。谢谢,

SQL执行顺序

带嵌套的Sql语句执行顺序问题

SQL语句执行顺序

sql查询语句的各个命令执行的标准顺序是啥?为啥?