码迷,mamicode.com
首页 > 其他好文 > 详细

左连接条件与where条件的区别

时间:2017-09-30 10:14:51      阅读:326      评论:0      收藏:0      [点我收藏+]

标签:查询   nbsp   数据   span   join   一对一   字段   否则   区别   

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 条件后面。

左连接条件与where条件的区别

标签:查询   nbsp   数据   span   join   一对一   字段   否则   区别   

原文地址:http://www.cnblogs.com/chaoshenzhu/p/7613604.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!