mysql left join中where和on条件的区别

本文详细解释了leftjoin中where和on条件的区别:where针对临时表过滤,可能排除记录;on用于右表条件过滤,即使左表条件不满足也返回所有左表行,可能导致行数增加。特别指出where对左表的限制应在on之前应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

时间:2018-11-21 01:21:23

left join中关于whereon条件的几个知识点:

    1.多表left join是会生成一张临时表,并返回给用户

    2.where条件是针对最后生成的这张临时表进行过滤,过滤掉不符合where条件的记录,是真正的不符合就过滤掉。

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

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

结论:

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值