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上
直接就是对结果集产生影响了。
本文标题:Oracle里面的外连中where和on之后and有啥区别-创新互联
本文来源:https://www.cdcxhl.com/article14/dsjide.html
成都网站建设公司_创新互联,为您提供面包屑导航、品牌网站建设、标签优化、域名注册、网站建设、品牌网站制作
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联