oracle中join连接执行次序,Oracle 中left join on and 和left join on where 的执行顺序
表1 tab1:id size1 102 203 30表2 tab2:size name10 AAA20 BBB20 CCCselect * form tab1 left join tab2 on (tab1.size = tab2.size and tab2.name='AAA')1、中间表on条件:tab1.size = tab2.size and tab2.name='AAA'(条件不为真也
表1 tab1:
id size
1 10
2 20
3 30
表2 tab2:
size name
10 AAA
20 BBB
20 CCC
select * form tab1 left join tab2 on (tab1.size = tab2.size and tab2.name='AAA')
1、中间表
on条件:
tab1.size = tab2.size and tab2.name='AAA'
(条件不为真也会返回左表中的记录)
tab1.id tab1.size tab2.size tab2.name
1 10 10 AAA
2 20 (null) (null)
3 30 (null) (null)
执行过程是:总共只有一个中间表,在这个中间表中,他会判断 tab1.size=tab2.size,并且过滤tab2.name="AAA";
select * form tab1 left join tab2 on (tab1.size = tab2.size) where tab2.name='AAA'
1、中间表
on条件:
tab1.size = tab2.size
tab1.id tab1.size tab2.size tab2.name
1 10 10 AAA
2 20 20 BBB
2 20 20 CCC
3 30 (null) (null)
2、再对中间表过滤
where 条件:
tab2.name='AAA'
tab1.id tab1.size tab2.size tab2.name
1 10 10 AAA
魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐



所有评论(0)