赞
踩
这三类表连接方式是oracle最基本的连接方式:
嵌套循环连接(nested loops join)原理
哈希连接(hash join) 原理
排序合并连接(sort merge join)
访问次数:两张表都只会访问0次或1次。排序合并连接原理:如果A表的数据为(2,1,4,5,2),B表的数据为(2,2,1,3,1) ,首先将A表和B表全扫描后排序,如下:
A B
1 1
2 1
2 2
4 2
5 3
因为没有驱动表,所以oracle会随机选择一张表驱动,如果选择了A扫描到1,然后扫描B,当扫描=1的时候则管理,当扫描到B=2时,再以B=2为驱动扫描A表,不是从1开始扫,而是从2开始扫描,交替的进行扫描、关联。
下面我们来做个试验:
SQL> set linesize 1000Plan hash value: 737852259
----解释一下:
Starts为该sql执行的次数。Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。