Oracle: 表连接提示

1 use_hash 关键点是:驱动表是小表
select /*+ use_hash(e,b) parallel(e,4) parallel(b,4) */ e.name
from emp e, bonus b
where e.name = b.ename[@more@]2 use_merge 提示强制执行一个排序合并操作
select /*+ use_merge(e,b) parallel(e,4) parallel(b,4) */ e.name
from emp e, bonus b
where e.name = b.ename
3 use_nl 提示强制对目标表执行嵌套循环连接
select /*+ use_nl(e) */ e.name
from emp e, bonus b
where e.name = b.ename
4 star 提示强制使用星形查询计划;前提是查询中至少有三个表,而且在事实表中存在恰当的index.
必须存在连接在一起的至少三个表,其中有一个大的事实表和几个小维度表
在事实表的字段上必须存在一个索引,这些字段将是在每个表的连接主键。
需要检验执行计划,确保在执行连接时使用嵌套循环操作
5 表反连接提示
计量避免使用NOT IN,应该使用NOEXT EXISTS代替。
6 merge_aj 反连接提示
select dname from dept
where deptno NOT IN
( select /*+ merge_aj */ deptno from emp)
7 hash_aj 反连接提示
select dname from dept
where deptno NOT IN
( select /*+ hase_aj */ deptno from emp)

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/640706/viewspace-1045422/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/640706/viewspace-1045422/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值