1、表做关联的时候有些条件写在where中,有些写在on之后关联条件的and中。那么有什么区别呢。
2、我们指导,表关联一般分为两种:内联和外联。
3、我们先来看内联。
4、准备两个表做连接。表A:test_tb_stid;表B:test_tb_stscore;
5、表A数据如下图:

6、表B数据如下图:

7、用红色字段stid作为关联条件
8、内联,先把过滤条件放在and后:
select a.*,b.*
from test_tb_stid a
inner join test_tb_stscore b
on a.stid = b.stid
and a.stid = 2
9、结果,发现只出现一条:

10、把过滤条件放到where

11、发现内联的时候,这个过滤条件放on之后的and和where没有区别。
12、我们再看一下外联。

发现虽然加了过滤条件,但是a表还是全量的。如果不加这个a.stid=1,应该会匹配出两条出来,如下图:

说明外联的话:1、主表总是全量的。2、on之后的and条件只对结果内容产生影响,不对结果量产生影响。
13、过滤条件加到where上

直接就是对结果集产生影响了。
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/69904754/viewspace-2642412/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/69904754/viewspace-2642412/
本文探讨了SQL中外联和内联查询中过滤条件放置的位置差异。通过实例演示了条件放置在ON子句后的AND与WHERE子句的区别,特别是在影响结果集数量与内容方面。
1509

被折叠的 条评论
为什么被折叠?



