澳门二十一点游戏赌场 澳门二十一点游戏赌场
    您现在的位置:首页 >> 软件应用 >> SQL教程 >> 内容

    如何使用USE_CONCAT提示

    时间:2012/7/23 20:04:33 点击:

      核心提示:使用USE_CONCAT提示--Use USE_CONCAT hints in Oracle Last Updated: Thursday, 2004-11-18 21:48 Eygle USE_CO...

    使用USE_CONCAT提示

    --Use USE_CONCAT hints in Oracle

    Last Updated: Thursday, 2004-11-18 21:48 Eygle
        
     


     

    USE_CONCAT提示强迫优化器扩展查询中的每一个OR谓词为独立的查询块.
    最后合并所有查询块的结果,返回结果集给用户。

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

    使用USE_CONCAT提示示例:

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


    $ sqlplus scott/tigerSQL*Plus: Release 9.2.0.4.0 - Production on Wed Nov 17 15:17:51 2004Copyright (c) 1982, 2002, Oracle Corporation. All rights reserved.Connected to:Oracle9i Enterprise Edition Release 9.2.0.4.0 - 64bit ProductionWith the Partitioning, OLAP and Oracle Data Mining optionsJServer Release 9.2.0.4.0 - ProductionSQL> set autotrace onSQL> 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 30Execution 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 20Execution 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 processedSQL>

    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。

     

    本文作者:
    eygle,Oracle技术关注者,来自中国最大的Oracle技术论坛itpub.
    www.eygle.com是作者的个人站点.你可通过Guoqiang.Gai@gmail.com来联系作者.欢迎技术探讨交流以及链接交换.

    原文出处:

    http://www.eygle.com/sql/How.to.Use.USE_CONCAT.hints.in.Oracle.htm

     

    作者:佚名 来源:不详

    共有评论 0相关评论
    发表我的评论
    • 大名:
    • 内容:
  • 澳门二十一点游戏赌场(www.0769online.com) © 2019 版权所有 All Rights Reserved. 邮箱:103150@qq.com 业务QQ:103150 手机:13549753683

    Power By Laoy8 SQL 3.0SP1 粤ICP备10098668号
  •