• 带Left Join的SQL语句的执行顺序


    基础的SQL执行顺序

    SQL语句执行的时候是有一定顺序的。理解这个顺序对SQL的使用和学习有很大的帮助。

    1.from

           先选择一个表,或者说源头,构成一个结果集。

    2.where

           然后用where对结果集进行筛选。筛选出需要的信息形成新的结果集。

    3.group by

           对新的结果集分组。

    4.having

          筛选出想要的分组。

    5.select

         选择列。

    6.order by

         当所有的条件都弄完了。最后排序。

     

    带连接的SQL语句执行顺序(以Left Join为列)

     

    我的理解是这样,SQL语句中无论是否连接的其他表。 无论如何都要先形成一个结果集。后面的顺序不变!

    只不过使用连接时,形成结果集合的方式略有不同。这个和 Left Join的实现原理有关。

    select a.name,b.name

    from T_left a            //1

    Left Join T_Right b   //3

    ON  a.id = b.id         //2

    使用Left Join 形成结果集的方式是这样的。

    1. 首先对From子句中的前两个表,执行笛卡尔积运算。运算结果 形成一个结果集合。

    clipboard

    2. ON按条件,对上边的结果集,进行筛选,形成新的结果集。

    clipboard[1]

    3. 以左连接为例,如果T_left中存在未匹配到的行。那么把T_left中的这几行以外部行的形式加到上边的结果集中形成新的结果集。

    clipboard[2]

    4. 如果存在多张表,重复1~3过程!

     

  • 相关阅读:
    MySQL select语句中where条件的提取过程
    MySQL特性:ICP,Index Condition Pushdown
    MySQL特性:BKA,Batched Key Access,批量索引访问
    MySQL特性:MRR,Multi-Range Read,多范围读
    show engine innodb status 输出结果解读
    IPv6的一点使用小计
    MySQL 通过ibd恢复数据
    explain 小结
    clickhouse的多路径存储策略
    cenos6.5升级glibc2.18
  • 原文地址:https://www.cnblogs.com/mcad/p/4207033.html
Copyright © 2020-2023  润新知