mysql使⽤leftjoin需要注意的点
含义:LEFT JOIN 关键字会从左表 (table_name1) 那⾥返回所有的⾏,即使在右表 (table_name2) 中没有匹配的⾏。
Mysql对于left join采⽤类似嵌套循环的⽅式进⾏处理,例如:
SELECT * FROM LT LEFT JOIN RT ON P1(LT,RT)) WHERE P2(LT,RT)多表left join
其中p1是on的过滤条件,缺失则认为rue,p2是where过滤条件,缺失也认为是true,该语句的执⾏逻辑可以描述为:
FOR each row lt in LT{//遍历左表的每⼀⾏
BOOL b = FALSE;
FOR each row in RT such that P1(lt,rt){//遍历右表的每⼀⾏,到满⾜on条件的⾏
IF P2(lt,rt){//满⾜where过滤条件
t:=lt||rt;//合并⾏,输出该⾏
}
b=true;//lt在RT中有对应的⾏
}
IF(!b){//遍历完RT,发现lt在Rt中没有对应的⾏,则尝试null补⼀⾏
IF P2(lt,null){//补上null后满⾜where过滤条件
t:=lt||null;//输出lt和null补上的⾏
}
}
}
从中可以看出两点:
1、如果想要对右表进⾏限制,则⼀定要在on条件中进⾏,若在where条件中进⾏,则可能导致数据缺
失,导致左表在右表中⽆匹配⾏的⾏在最终结果中不出现,违背了我们对leftjoin的理解。因为对左表⽆右表匹配⾏的⾏⽽⾔,遍历右表后b=false,所以会尝试⽤null补齐右表,但是此时我们的P2对右表进⾏了限制,null若不满⾜P2(null⼀般都不会满⾜限制条件,除⾮ is null这种),则不会加⼊最终的结果中,导致结果缺失。
2、如果没有where条件,⽆论on条件对左边进⾏怎样的限制,左表的每⼀⾏都⾄少会有⼀⾏的合成结果,对左表⾏⽽⾔,若右表没有对应的⾏,则右表遍历结束后b=false,会⽤⼀⾏null来⽣成数据,⽽这个数据是多余的,所以对左表进⾏过滤必须使⽤where。
总结:
1.多表left join是会⽣成⼀张临时表,并返回给⽤户
2.where条件是针对最后⽣成的这张临时表进⾏过滤,过滤掉不符合where条件的记录,是真正的不符合就过滤掉。
<条件是对left join的右表进⾏条件过滤,但依然返回左表的所有⾏,右表中没有的补为NULL
<条件中如果有对左表的限制条件,⽆论条件真假,依然返回左表的所有⾏,但是会影响右表的匹配值。也就是说on中左表的限制条件只影响右表的匹配内容,不影响返回⾏数。
结论:
1.where条件中对左表限制,不能放到on后⾯
2.where条件中对右表限制,放到on后⾯,会有数据⾏数差异,⽐原来⾏数要多
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论