Oracle LEFT JOIN中ON条件与WHERE条件的区别
来源:互联网 发布:最受欢迎的网络歌手 编辑:程序博客网 时间:2024/05/16 10:05
Oracle LEFT JOIN中ON条件与WHERE条件的区别
JOIN中的ON条件与WHERE条件是一样的,而LEFT JOIN却不一样
SQL> create table t1 as select * from scott.emp;
表已创建。
SQL> create table t2 as select * from scott.dept;
表已创建。
SQL> delete t2 where deptno=30;
已删除 1行。
以下为使用where的查询结果与执行计划
以下为使用on条件的查询结果与执行计划
oracle 对谓词and t1.job='CLERK'(on 后面的),where t1.job='CLERK'的解析是不一样的。
使用where t1.job='CLERK':
1 - access("T1"."DEPTNO"="T2"."DEPTNO"(+))
2 - filter("T1"."JOB"='CLERK')
Oracle 先根据"T1"."JOB"='CLERK'对T1表进行过滤,然后与T2表进行左外连接
Oracle解析的谓词and t1.job='CLERK'(on 后面的)为:
1 - access("T1"."DEPTNO"="T2"."DEPTNO"(+) AND "T1"."JOB"=CASE WHEN
("T2"."DEPTNO"(+) IS NOT NULL) THEN 'CLERK' ELSE 'CLERK' END )
代表什么意思呢?
oracle 对t1,t2进行全表扫描,之后进行左外连接(也可能是在扫描过程中进行连接),而and t1.job='CLERK'对连接之后的记录总数没有影响,只是对不符合and t1.job='CLERK'的记录中的部门名称置为空
on中的条件限制
SQL> select * from tab1; ID SIZE1---------- ---------- 1 10 2 20 3 30SQL> select * from tab2; SIZE1 NAME---------- -------------------- 10 AAA 20 BBB 20 CCCSQL> select tab1.*,tab2.* from tab1 left join tab2 on (tab1.size1= tab2.size1) ; ID SIZE1 SIZE1 NAME---------- ---------- ---------- -------------------- 1 10 10 AAA 2 20 20 BBB 2 20 20 CCC 3 30SQL> select tab1.*,tab2.* from tab1 left join tab2 on (tab1.size1= tab2.size1 and tab1.id=2); ID SIZE1 SIZE1 NAME---------- ---------- ---------- -------------------- 1 10 2 20 20 BBB 2 20 20 CCC 3 30SQL> select tab1.*,tab2.* from tab1 left join tab2 on (tab1.size1= tab2.size1 and tab2.name='AAA'); ID SIZE1 SIZE1 NAME---------- ---------- ---------- -------------------- 1 10 10 AAA 3 30 2 20SQL> select tab1.*,tab2.* from tab1 left join tab2 on (tab1.size1= tab2.size1 and tab2.name='BBB'); ID SIZE1 SIZE1 NAME---------- ---------- ---------- -------------------- 2 20 20 BBB 3 30 1 10SQL> select tab1.*,tab2.* from tab1 left join tab2 on (tab1.size1= tab2.size1 and tab2.name='CCC'); ID SIZE1 SIZE1 NAME---------- ---------- ---------- -------------------- 2 20 20 CCC 3 30 1 10SQL> update tab2 set name='DDD' where size1=20;已更新2行。提交完成。SQL> commit 2 ;提交完成。SQL> select tab1.*,tab2.* from tab1 left join tab2 on (tab1.size1= tab2.size1 and tab2.name='DDD'); ID SIZE1 SIZE1 NAME---------- ---------- ---------- -------------------- 2 20 20 DDD 2 20 20 DDD 3 30 1 10SQL> select tab1.*,tab2.* from tab1 left join tab2 on (tab1.size1= tab2.size1 and tab2.name='xxx'); ID SIZE1 SIZE1 NAME---------- ---------- ---------- -------------------- 3 30 2 20 1 10
当on中对左表的非连接字段限制时 与 对右表的非连接字段限制时 是两种不同的情况,请注意。
当on中对右表的非连接字段限制时(on (tab1.size1= tab2.size1 and tab2.name='AAA')) 相当于右表根据非连接字段限制获取结果,然后左表再与它关联。
select tab1.*,tab2.* from tab1 left join tab2 on (tab1.size1= tab2.size1 and tab2.name='AAA');
相当于
select tab1.*,t.* from tab1 left join (select * from tab2 where tab2.name='AAA') t on (tab1.size1= t.size1);
- Oracle LEFT JOIN中ON条件与WHERE条件的区别
- left join加上on条件与where条件区别
- MySQL left join操作中 on与where放置条件的区别
- left join on后的条件与where后的条件的区别
- left join on、where后面的条件的区别
- left join on、where后面的条件的区别
- left join (on 和 where条件放置的区别)
- left join on 和where条件的放置 区别
- left join (on 和 where条件放置的区别)
- left join(on和where条件放置的区别)
- left jion on条件与where条件的区别
- oracle数据库sql语句left join,right join,inner join的条件on和where的区别
- MYSQL联表查询LEFT JOIN 中 WHERE条件放在ON条件里和外部的区别
- left join,right join,inner join的条件on和where的区别
- left join on后面 加条件和where后面加条件的区别
- left join条件写在on中和where中的区别
- oracle中left join中on和where的区别
- oracle中left join中on和where的区别
- 设计Qt风格的C++API【转
- SQL Server 2008/2012中SQL应用系列及BI学习笔记系列--目录索引
- 使用jqGrid问题解决方法
- poj 2404
- 优化SQL CPU性能
- Oracle LEFT JOIN中ON条件与WHERE条件的区别
- java设置classpath,path,java_home环境变量
- android小游戏 开发-推广-盈利 介绍
- 改桌面背景
- String类的进一步学习二
- SQL2008压缩清除日志方法
- window.location.reload()与window.location.href区别
- Java中的内省
- How to manage a Thread IN ASP.NET