mysql left join 中文_mysql使用left join需要注意的点

含义:LEFT JOIN 关键字会从左表 (table_name1) 那里返回所有的行,即使在右表 (table_name2) 中没有匹配的行。

Mysql对于left join采用类似嵌套循环的方式进行处理,例如:

SELECT * FROM LT LEFT JOIN RT ON P1(LT,RT)) WHERE P2(LT,RT)

其中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条件的记录,是真正的不符合就过滤掉。

3.on条件是对left join的右表进行条件过滤,但依然返回左表的所有行,右表中没有的补为NULL

4.on条件中如果有对左表的限制条件,无论条件真假,依然返回左表的所有行,但是会影响右表的匹配值。也就是说on中左表的限制条件只影响右表的匹配内容,不影响返回行数。

结论:

1.where条件中对左表限制,不能放到on后面

2.where条件中对右表限制,放到on后面,会有数据行数差异,比原来行数要多

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值