带LeftJoin的SQL语句的执⾏顺序
基础的SQL执⾏顺序
SQL语句执⾏的时候是有⼀定顺序的。理解这个顺序对SQL的使⽤和学习有很⼤的帮助。
1.from
先选择⼀个表,或者说源头,构成⼀个结果集。
2.where
然后⽤where对结果集进⾏筛选。筛选出需要的信息形成新的结果集。
对新的结果集分组。
4.having
筛选出想要的分组。
5.select
选择列。
当所有的条件都弄完了。最后排序。
sql left join 多表连接带连接的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过程!
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论