Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1283692
  • 博文数量: 127
  • 博客积分: 2286
  • 博客等级: 大尉
  • 技术积分: 1943
  • 用 户 组: 普通用户
  • 注册时间: 2010-06-10 10:37
文章分类

全部博文(127)

文章存档

2018年(1)

2015年(2)

2014年(1)

2013年(30)

2012年(88)

2011年(5)

分类: Oracle

2012-02-08 13:51:17

使用Semi-Joins和Anti-Joins有的时候能大幅度提高查询的速度,减少IO但它们的使用是有条件的

总结备查:

Semi-Joins用EXISTS或IN的查询

HINT:NL_SJ MERGE_SJ HASH_SJ

前提条件:

1. 查询中不能有任何显式或隐式的distinct操作

2. Where中可以有OR,但EXISTS或IN不能是OR的分支


Anti-Joins用于NOT EXISTS或NOT IN的查询

HINT:NL_AJ MERGE_AJ HASH_AJ

前提条件:

子查询不能返回空值,用以下的方法:

1. 该字段声明为not null

2. 子查询的select中用nvl

3. 子查询的where后加上not null条件



阅读(1493) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~