Sql 查询语句应用左连接时的链接条件中经常加一些常量值在里面如:
“On a.id= b.id and b.is_del =0 and b.is_old =1” 这种条件如果加在表与表之间连接后的where条件中时有什么不一样呢?
答:其实仔细想想我们都能想到,左连接的目的是要取左边的所有数据,如果条件中右边表中的字段与左边表中的字段是一对一关系,那连接时要保证右边数据不为null,只能让”a.id = b.id and b.is_del =0,b.is_old=1”;否则即使a.id=b.id 满足条件同样右边的数据只能用null来补全,这种情况下如果左边有10条数据,右边只有7条数据完全符合条件,那结果就是有10条数据显示出来只不过有三条数据右边表中的数据是null;如果将此b.is_del = 0 and b.is_old =1 放在where后面那么就会发现结果中一共有7条数据那三条空数据已经被删除了,这就是区别。
总结一下规律:
放在on里面就是先筛选后连接,保证连接左边数据完整;放在where中就得先连接后筛选。
如果使用INNER JOIN 效果是一样的所以建议同一放在where 条件后面。