mysql join 使用

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

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

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

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

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

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

结论:

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

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

https://www.cnblogs.com/cuisi/p/7685893.html

 

SQL优化--inner、left join替换in、not in、except

https://www.cnblogs.com/zhangdk/p/notintoleftjoin.html

 

SQL语法——left join on 多条件

https://blog.csdn.net/minixuezhen/article/details/79763263

MySQL的连接查询:left join , right join , join

https://blog.csdn.net/lp_cq242/article/details/79942457

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值