---------------------------------------------嵌套连接
嵌套循环,顾名思义就是将一个表为出发点,将该表全部记录逐条去遍历另外一张表的记录,符合条件的就是写入结果集。

SELECT /*+ leading(t1) use_nl(t2) full(t1) full(t2) */*
FROM t1,t2 WHERE t1.id = t2.id AND t1.n = 19
执行计划如下:










select a.*, b *
from EMP a, DEPT b
where a.DEPTNO = b.DEPTNO;
使用伪代码来表示一下嵌套循环连接
declare
begin
for outer_table in (select * from emp) loop
for inner_table in (select *
from dept
where DEPTNO = outer_table.DEPTNO) loop
dbms_output.put_line(inner_table.*, outer_table.*);
end loop;
end loop;
end;
---------------------------------------------哈希连接
a) 这种方法是在Oracle7后来引入的,使用了比较先进的连接理论,一般来说,其效率应该好于其它2种连接,但是这种连接只能用在CBO优化器中,而且需要设置合适的hash_area_size参数,才能取得较好的性能。
b) 在2个较大的row source之间连接时会取得相对较好的效率,在一个row source较小时则能取得更好的效率。
c) 只能用于等值连接中
---------------------------------------------笛卡儿乘积
当两个row source做连接,但是它们之间没有关联条件时,就会在两个row source中做笛卡儿乘积,这通常由编写代码疏漏造成(即程序员忘了写关联条件)。笛卡尔乘积是一个表的每一行依次与另一个表中的所有行匹配。在特殊情况下我们可以使用笛卡儿乘积,如在星形连接中,除此之外,我们要尽量使用笛卡儿乘积,否则,自己想结果是什么吧!
注意在下面的语句中,在2个表之间没有连接。
- SQL> explain plan for
- select emp.deptno,dept,deptno
- from emp,dept
- Query Plan
- SLECT STATEMENT [CHOOSE] Cost=5
- MERGE JOIN CARTESIAN
- TABLE ACCESS FULL DEPT
- SORT JOIN
- TABLE ACCESS FULL EMP
CARTESIAN关键字指出了在2个表之间做笛卡尔乘积。假如表emp有n行,dept表有m行,笛卡尔乘积的结果就是得到n * m行结果。