当前位置: 首页 > news >正文

如何使用USE_CONCAT提示

使用USE_CONCAT提示

--Use USE_CONCAT hints in Oracle

Last Updated: <!-- #BeginDate format:wfcIS1m -->Thursday, 2004-11-18 21:48<!-- #EndDate --> Eygle

<!--DWLayoutEmptyCell-->

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。

本文作者:
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


相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • win10 rdkit下载及使用
  • openJDK清华镜像源安装
  • python输出太长有省略号的解决办法
  • pycharm连接远程服务器
  • python保存训练好的模型、加载模型
  • Rdkit常用命令/参数设置
  • python按列标题读取csv内容
  • rdkit 识别反应中心
  • 识别反应中心原子
  • windows 脚本中心
  • git 一些报错
  • 算法图解笔记(整合)
  • 摄影相关网址
  • linux系统pytorch重装
  • conda安装某些包时找不到合适的源
  • [PHP内核探索]PHP中的哈希表
  • python3.6+scrapy+mysql 爬虫实战
  • 【个人向】《HTTP图解》阅后小结
  • 345-反转字符串中的元音字母
  • axios 和 cookie 的那些事
  • centos安装java运行环境jdk+tomcat
  • CSS 三角实现
  • Druid 在有赞的实践
  • Fundebug计费标准解释:事件数是如何定义的?
  • JavaScript标准库系列——Math对象和Date对象(二)
  • leetcode98. Validate Binary Search Tree
  • node 版本过低
  • oldjun 检测网站的经验
  • PAT A1092
  • Spring Cloud中负载均衡器概览
  • windows-nginx-https-本地配置
  • 从伪并行的 Python 多线程说起
  • 等保2.0 | 几维安全发布等保检测、等保加固专版 加速企业等保合规
  • 高度不固定时垂直居中
  • 构建二叉树进行数值数组的去重及优化
  • 缓存与缓冲
  • 经典排序算法及其 Java 实现
  • 精益 React 学习指南 (Lean React)- 1.5 React 与 DOM
  • 类orAPI - 收藏集 - 掘金
  • 聊聊flink的BlobWriter
  • 前端每日实战:70# 视频演示如何用纯 CSS 创作一只徘徊的果冻怪兽
  • 前端面试之闭包
  • 适配mpvue平台的的微信小程序日历组件mpvue-calendar
  • 通过几道题目学习二叉搜索树
  • 我建了一个叫Hello World的项目
  • Java性能优化之JVM GC(垃圾回收机制)
  • ​无人机石油管道巡检方案新亮点:灵活准确又高效
  • !!java web学习笔记(一到五)
  • ###C语言程序设计-----C语言学习(6)#
  • #我与Java虚拟机的故事#连载14:挑战高薪面试必看
  • (2024,RWKV-5/6,RNN,矩阵值注意力状态,数据依赖线性插值,LoRA,多语言分词器)Eagle 和 Finch
  • (2024.6.23)最新版MAVEN的安装和配置教程(超详细)
  • (26)4.7 字符函数和字符串函数
  • (android 地图实战开发)3 在地图上显示当前位置和自定义银行位置
  • (day 12)JavaScript学习笔记(数组3)