ITPub博客

首页 > 数据库 > Oracle > Oracle: 表连接提示

Oracle: 表连接提示

原创 Oracle 作者:liang573728 时间:2019-05-09 09:12:05 0 删除 编辑
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/,如需转载,请注明出处,否则将追究法律责任。

下一篇: ORACLE index提示
请登录后发表评论 登录
全部评论

注册时间:2005-10-15

  • 博文量
    139
  • 访问量
    101974