oracle use 代表什么意思,使用USE_CONCAT提示

使用USE_CONCAT提示

6ee5639a40442445944d63b514b2dd02.png

USE_CONCAT提示强迫优化器扩展查询中的每一个OR谓词为独立的查询块.

最后合并所有查询块的结果,返回结果集给用户。

当使用多个in-lists查询时,Oracle可能选择把单个查询扩展为多个查询块。

使用USE_CONCAT提示示例:

1.使用scott用户及标准表进行测试

$ sqlplus scott/tiger

SQL*Plus: Release 9.2.0.4.0 - Production on Wed Nov 17 15:17:51 2004

Copyright (c) 1982, 2002, Oracle Corporation. All rights reserved.

Connected to:

Oracle9i Enterprise Edition Release 9.2.0.4.0 - 64bit Production

With the Partitioning, OLAP and Oracle Data Mining options

JServer Release 9.2.0.4.0 - Production

SQL> set autotrace on

SQL> select * from emp where empno in (7788,7900);

EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO

---------- ---------- --------- ---------- --------- ---------- ---------- ----------

7788 SCOTT ANALYST 7566 19-APR-87 3000 20

7900 JAMES CLERK 7698 03-DEC-81 950 30

Execution Plan

----------------------------------------------------------

0 SELECT STATEMENT Optimizer=CHOOSE (Cost=2 Card=2 Bytes=74)

1 0 TABLE ACCESS (FULL) OF 'EMP' (Cost=2 Card=2 Bytes=74)

--注意,此处Oracle选择了全表扫描,因为成本较低。

Statistics

----------------------------------------------------------

0 recursive calls

0 db block gets

4 consistent gets

0 physical reads

0 redo size

1032 bytes sent via SQL*Net to client

655 bytes received via SQL*Net from client

2 SQL*Net roundtrips to/from client

0 sorts (memory)

0 sorts (disk)

2 rows processed

2.添加提示

SQL> select /*+ use_concat */ * from emp where empno in (7788,7900);

EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO

---------- ---------- --------- ---------- --------- ---------- ---------- ----------

7900 JAMES CLERK 7698 03-DEC-81 950 30

7788 SCOTT ANALYST 7566 19-APR-87 3000 20

Execution Plan

----------------------------------------------------------

0 SELECT STATEMENT Optimizer=CHOOSE (Cost=4 Card=2 Bytes=74)

1 0 CONCATENATION

2 1 TABLE ACCESS (BY INDEX ROWID) OF 'EMP' (Cost=2 Card=1 Bytes=37)

3 2 INDEX (UNIQUE SCAN) OF 'PK_EMP' (UNIQUE) (Cost=1 Card=14)

4 1 TABLE ACCESS (BY INDEX ROWID) OF 'EMP' (Cost=2 Card=1 Bytes=37)

5 4 INDEX (UNIQUE SCAN) OF 'PK_EMP' (UNIQUE) (Cost=1 Card=14)

--使用use_concat提示以后,Oracle将in-lists条件展开为两个查询块,分别使用索引,最后CONCATENATION得到最后输出。

--注意,这里强制使用索引导致成本上升为4。

Statistics

----------------------------------------------------------

0 recursive calls

0 db block gets

4 consistent gets

0 physical reads

0 redo size

1032 bytes sent via SQL*Net to client

655 bytes received via SQL*Net from client

2 SQL*Net roundtrips to/from client

0 sorts (memory)

0 sorts (disk)

2 rows processed

SQL>

3.Oracle对于执行计划的改写

对于inlist查询,Oracle通常会进行改写,将形如

select ..... from ....... where ....in (..........)

的sql语句,改写为union all的形式来执行,这个改写通常是潜在的。

然而这一改写可能存在问题,如果inlist中的值比较多的话,CBO花在分析执行路径上的时间和成本都会相当大,此时我们通常需要阻止Oracle的这一展开操作.

我们可以通过NO_EXPAND提示来阻止Oracle进行这样的改写。

那么实际上,在这里,USE_CONCAT和NO_EXPAND成了互为"反函数"。在使用了NO_EXPAND提示后,从Oracle8之后,Oracle会使用"inlist iterator"

方式来执行SQL,这样可以用到index。

By eygle on 2004-11-18 16:38 |

Comments (0) |

SQL.PLSQL | 98 |

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值