Oracle数据库的表连接方式
来源:互联网 发布:企业网站怎样优化 编辑:程序博客网 时间:2024/04/24 11:41
使用Oracle数据库,经常需要使用表之间的连接,即Join操作。
Oracle中的连接方式主要有:
- SORT MERGE JOIN
- NESTED LOOPS
- HASH JOIN
那么这三种连接方式到底是何含义呢?下面都假设使用A和B表来连接,连接条件涉及的列分别是A表的cola列,B表的colb列,经典的查询语句形如:
SELECT A.c1,A.c2,B.d1,B.d2 where A.cola=B.colb
这三种连接方式的主要含义是:
- SORT MERGE JOIN
对A表按照cola列排序;对B表按照colb列排序;将两个表按照条件合并(连接)。
- NESTED LOOPS
for(r in outerTable_Rows){
if(r match innerTable_Rows)
output r;
}
- HASH JOIN
算法其实很复杂,大体情况是: 将驱动表(外表)的数据按照条件过滤,并做Hash,置入内存;同样将从表(内表)按照条件过滤,并作Hash;逐一检测内表中各行的hash,符合条件的输出,不符合的丢弃。
对照到实际使用中,在SQL中经常用到EXISTS、IN、NOT EXISTS 、NOT IN
需要注意其本质区别:
- EXISTS :对外表进行循环,逐一与内表(子查询中的条件用表)匹配,类似于NESTED LOOPS。因为内表通常可以用上索引,所以EXISTS的主要开销在外表的记录数多少,这样外表记录越少,EXISTS语句的效率越高。
- IN:对外表和内表做HASH JOIN。如果IN里面不是一个子查询,而是一组固定值,那么和一大堆OR语句是一样的。
- NOT IN :内外表全部都是TABLE ACCESS FULL ,什么索引也用不上
- NOT EXISTS:子查询上的表能够用上索引
- Oracle数据库的表连接方式
- Oracle数据库表的连接方式
- oracle数据库的连接方式
- 连接访问oracle数据库的方式
- 连接mysql,oracle,sqlServer数据库的方式
- Oracle数据库常见的四种表连接方式
- Oracle 数据库的连接方式实现方法
- oracle表连接的方式
- Java连接Oracle数据库的三种连接方式
- Oracle数据库oci连接方式
- .NET连接oracle数据库方式
- oracle数据库用户连接方式
- 使用连接池的方式连接数据库:使用DBUtil连接ORACLE数据库
- 连接数据库的方式
- 数据库的连接方式
- 连接数据库的方式
- Java连接oracle数据库-------jdbc的thin方式
- VC++和Oracle数据库的三种连接方式
- 电路知识
- 编译期判断有向图中是否有环
- 阿拉伯数字转换成金额大写金额(包括小数)
- android 适配器Adpter的使用总结
- Objective-C中const常量是外连接的
- Oracle数据库的表连接方式
- SAX解析XML 简单例子
- 字符串函数总结
- LINUX中的SHELL
- Objective-C学习笔记2:类、对象和方法
- Node服务器程序面向对象编程
- erlang 列表解析,变位词解析过程
- 如何看一个大型的项目代码
- chapter two学习笔记----章节回忆