码迷,mamicode.com
首页 > 数据库 > 详细

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

时间:2015-01-06 22:54:18      阅读:317      评论:0      收藏:0      [点我收藏+]

标签:

基础的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子句中的前两个表,执行笛卡尔积运算。运算结果 形成一个结果集合。

技术分享

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

技术分享

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

技术分享

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

 

 

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

标签:

原文地址:http://www.cnblogs.com/mcad/p/4207033.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!