美文网首页
SQL语句书写顺序与执行顺序

SQL语句书写顺序与执行顺序

作者: 羋学僧 | 来源:发表于2023-02-11 16:24 被阅读0次

    SQL语句书写顺序与执行顺序

    SQL 语句的书写顺序与执行顺序不是一致的,我们通过这节课来搞清楚

    1、书写顺序

    书写顺序是这样的

    SELECT <字段名> 
    FROM <表名>
    JOIN <表名> 
    ON <连接条件>
    WHERE <筛选条件>
    GROUP BY <字段名>
    HAVING <筛选条件>
    UNION
    ORDER BY <字段名>
    LIMIT <限制行数>;
    

    2、执行顺序

    • 1.FORM:选择from后面跟的表,产生虚拟表1。
    • 2.ON:ON是JOIN的连接条件,符合连接条件的行会被记录在虚拟表2中。
    • 3.JOIN:如果指定了LEFT JOIN,那么保留表中未匹配的行就会作为外部行添加到虚拟表2中,产生虚拟表3。如果有多个JOIN链接,会重复执行步骤1~3,直到处理完所有表。
    • 4.WHERE:对虚拟表3进行WHERE条件过滤,符合条件的记录会被插入到虚拟表4中。
    • 5.GROUP BY:根据GROUP BY子句中的列,对虚拟表2中的记录进行分组操作,产生虚拟表5。
    • 6.HAVING:对虚拟表5进行HAVING过滤,符合条件的记录会被插入到虚拟表6中。
    • 7.SELECT:SELECT到一步才执行,选择指定的列,插入到虚拟表7中。
    • 8.UNION:UNION连接的两个SELECT查询语句,会重复执行步骤1~7,产生两个虚拟表7,UNION会将这些记录合并到虚拟表8中。
    • 9.ORDER BY: 将虚拟表8中的记录进行排序,虚拟表9。
    • 10.LIMIT:取出指定行的记录,返回结果集。

    3、总结:

    书写顺序:

    SELECT -> FROM -> JOIN -> ON -> WHERE -> GROUP BY -> HAVING -> UNION -> ORDER BY ->LIMIT
    

    执行顺序:

    FROM -> ON -> JOIN -> WHERE -> GROUP BY -> HAVING -> SELECT -> UNION -> ORDER BY ->LIMIT
    

    4、需要注意的地方:

    • 1.SELECT语句总是写在最前面,但在大部分语句之后才执行。所以在SQL语句中,我们不能在WHERE、GROUP BY、 HAVING语句中使用在 SELECT 中设定的别名。

    但是MYSQL有个特性,在GROUP BY、 HAVING语句中,可以使用 SELECT 中设定的别名。这不是因为MYSQL中会提前执行SELECT,而是因为在GROUP BY这一步返回了游标,大家了解一下就好。

    • 2.无论是书写顺序,还是执行顺序,UNION 都是排在 ORDER BY 前面的。SQL语句会将所有UNION 段合并后,再进行排序。

    相关文章

      网友评论

          本文标题:SQL语句书写顺序与执行顺序

          本文链接:https://www.haomeiwen.com/subject/upxrkdtx.html