关于left join 和 on 的小问题

AI摘要
本文指出LEFT JOIN使用中的常见误区:WHERE条件可能使其退化为INNER JOIN。核心要点是:若要保持LEFT JOIN特性(左表数据全保留,右表不匹配则补NULL),应将右表筛选条件置于ON子句中,而非WHERE子句。

首先,大家都清楚,left join 是以左边为主的联查,并且我们代码中,也是left join使用率比较高。

但是要注意几点:
1、尽管你使用了left join,并不是说左表的数据都会查出来,比如

select * from t1 left join t2 on t2.id=t1.t2Id 
where t1.id In(1,2,3) 
AND 
t2.type In('eat', 'drink');

// 此时就类似 inner join 的效果了

2、如果你依旧想要left join的效果为:左边满足的都出现,右边不满足的为null,把右表的条件放在on中

select * from t1 
left join t2 
on t2.id=t1.t2Id and t2.type In('eat', 'drink');
where t1.id In(1,2,3)
本作品采用《CC 协议》,转载必须注明作者和本文链接
六月的风
Junwind
讨论数量: 0
(= ̄ω ̄=)··· 暂无内容!

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!
躺平大叔 @ 躺平社区
文章
144
粉丝
17
喜欢
107
收藏
62
排名:258
访问:3.7 万
私信
所有博文
社区赞助商