一、概念
合并连接:MERGE JOIN,也叫排序合并连接,进行合并连接的时候,两个数据集都会被读出来,并按照连接条件的字段进行排序。当这些操作完成,两个工作区的内容就会被合并。
二、特点
- 每个子节点只会执行一次。
- 每个输入数据集都必须按照连接条件的字段进行排序。
- 由于这些排序操作,在返回结果集的第一条记录之前,两个输入数据集都必须被完全读出并排序。
- 所有的连接类型都支持合并连接。
- 合并连接并不是经常使用。原因是大部分情况下,合并连接的效率不如嵌套循环连接和哈希连接。无论如何,这种连接方法是必要的,因为只有他才支持所有类型的连接;
三、执行步骤
四、合并连接的测试
测试环境:
数据库版本:11.2.0.3
表:SCOTT.DEPT
表: SCOTT.EMP
select /*+ ordered use_merge(EMP) */*
FROM SCOTT.DEPT T1,SCOTT.EMP T2
WHERE T1.DEPTNO=T2.DEPTNO;
执行计划的解读如下:
1.表DEPT上面有主键索引PK_DEPT,所以通过这个索引去获取数据,读取数据的时候直接进行排序;
2.对表EMP记录通过一次全表扫描读出,然后进行SORT的排序;
3.两个数据集进行连接,结果记录返回;
4.根据执行的原理可以明白,合并连接的最大的局限是不能有效的利用索引来处理连接条件。索引只能作为排序操作之前的房屋路径去评估限制条件。
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
本文作者:JOHN
ORACLE技术博客:ORACLE 猎人笔记 数据库技术群:367875324 (请备注ORACLE管理 )
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++