zoukankan      html  css  js  c++  java
  • 带Left Join的SQL语句的执行顺序

    本文转载自:https://www.cnblogs.com/mcad/archive/2015/01/06/4207033.html 作者:mcad 转载请注明该声明。

    基础的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过程!

  • 相关阅读:
    用Django开发简单的POST/GET接口
    搭建Django环境
    用Django创建一个项目
    NodeJS服务器退出:完成任务,优雅退出
    linux 常用bash
    泛型笔记
    finderweb日志查看系统配置使用
    finderweb日志查看系统部署
    jenkins+gitlab自动部署代码
    jenkins 配置 git拉取代码
  • 原文地址:https://www.cnblogs.com/qfdy123/p/12546118.html
Copyright © 2011-2022 走看看