oracle hint 强制索引(转)

oracle

1.建议建立一个以paytime,id,cost的复合索引。光是在paytime上建立索引会产生很多随机读。
2.就算建立了索引,如果你查询的数据量很大的话,也不一定会用索引,有时候全表扫描速度比索引扫描要快!(官方文档上好像说的是大概10%,就是如果你查询的数据占到总数据的10%,全表扫描比索引快)。
3.建复合索引语句如下(建议去看看官方文档,建索引有很多参数,而且每个版本的ORACLE也不一定一样):
CREATE INDEXTEST_indexONCONSUME_test
(PAYTIME,ID, COST)
LOGGING
TABLESPACE INDEX_A
NOPARALLEL;
最后说一句,ORACLE好像没有“强制索引”的说法的!

追问:

我记得有强制索引啊,就是/*+这里面写的*/,但是我不知道语法

追答:

你指的是用hints去提示你查询语句去使用哪个索引。
SELECT   /*+INDEX(TABLE INDEX_NAME)*/ FROM TABLE
可以提示ORACLE 去使用TABLE 表上已经建好的INDEX_NAME。ORACLE 官方文档上说过,这并不是强制的,仅仅是提示,优化器可能会选择这个索引,也可能不选择。不过绝大部分情况会按照提示的去做!hints是oracle提供的一种机制,用来告诉优化器按照我们的告诉它的方式生成执行计划。我们可以用hints来实现:1) 使用的优化器的类型2) 基于代价的优化器的优化目标,是all_rows还是first_rows。3) 表的访问路径,是全表扫描,还是索引扫描,还是直接利用rowid。4) 表之间的连接类型5) 表之间的连接顺序6) 语句的并行程度2、HINT可以基于以下规则产生作用表连接的顺序、表连接的方法、访问路径、并行度3、HINT应用范围dml语句查询语句4、语法{DELETE|INSERT|SELECT|UPDATE} /*+ hint [text] [hint[text]]... */or{DELETE|INSERT|SELECT|UPDATE} --+ hint [text] [hint[text]]...如果语(句)法不对,则ORACLE会自动忽略所写的HINT,不报错例子:

在一些场景下,可能ORACLE不会自动走索引,这时候,如果对业务清晰,可以尝试使用强制索引,测试查询语句的性能。

以EMP表为例:

先在EMP表中建立唯一索引,如图。

普通搜索:

SELECT * FROM EMP T

查看执行计划:

可以看到,是走的全表扫描。

使用强制索引,在SELECT 后面加上/*.......*/ 中间加上索引的属性,代码如下:

SELECT /*+index(t pk_emp)*/* FROM EMP T   --强制索引,/*.....*/第一个星星后不能有空格,里边内容结构为:加号index(表名 空格 索引名)。
--如果表用了别名,注释里的表也要使用别名。

可以看到,这是走的是索引PK_EMP。

测试:

Oracle强制索引相关推荐

  1. oracle 强制索引_当唯一索引遇见分布式数据库

    这是Tank的第18篇文章 1 关于分片键 分布式数据库通过将表的数据打散,按一定规则将数据分布在多个独立的主机上,常见的策略如HASH.RANGE.LIST等分布方式.不考虑中间件的解决方案,在原生 ...

  2. oracle 强制索引 hint,oracle常用hint详解

    相对而言ORACLE优化器已经非常智能,产生的执行计划也是最优的,但是ORACLE还是提供了一些hint供用户显示的控制执行计划,因为大千世界各种各样的业务都有,ORACLE优化器生成的执行计划并不一 ...

  3. oracle 强制索引 hint,ORACLE进阶之一:HINT

    最近由于需要经常统计数据,需要经常用到hint,又不好意思每次都去麻烦DBA,所以在与DBA交流之后,整理了一份关于我们写ORACLE SQL语句时最常用到的hint使用方法: 另外,我们以前的流程都 ...

  4. oracle强制走索引_实验验证:Oracle聚簇因子对索引使用的影响

    [引言] 本文基于如下文章进行的实验,讲述聚簇因子对SQL索引的影响. 链接如下: https://www.modb.pro/db/40283 一张表上有索引,sql在执行的时候却不走索引的原因有很多 ...

  5. oracle hint 强制索引

    –用法 select /+index(表名(可用别名) 索引名称)/ –oracle hint 强制索引(只是建议oracle优化器走该索引,有该条语句时大概率会适应该索引,并不意味着oracle执行 ...

  6. oracle中强制走索引,Oracle数据库强制索引

    当where子句对某一列使用函数时,除非利用这个简单的技术强制索引,否则Oracle优化器不能在查询中使用索引. 通常情况下,如果在WHERE子句中不使用诸如UPPER.REPLACE 或SUBSTR ...

  7. oracle加强制索引,Oracle中建立索引并强制优化器使用

    当WHERE子句对某一列使用函数时,除非利用这个简单的技术强制索引,否则Oracle优化器不能在查询中使用索引. 通常情况下,如果在WHERE子句中不使用诸如UPPER.REPLACE 或SUBSTR ...

  8. MySQL force Index 强制索引概述

    以下的文章主要介绍的是MySQL force Index  强制索引,以及其他的强制操作,其优先操作的具体操作步骤如下:我们以MySQL中常用的hint来进行详细的解析,如果你是经常使用Oracle的 ...

  9. MYSQL中常用的强制性操作(例如强制索引)

    对于经常使用oracle的朋友可能知道,oracle的hint功能种类很多,对于优化sql语句提供了很多方法.同样,在mysql里,也有类似的hint功能. 其他强制操作,优先操作如下: mysql常 ...

最新文章

  1. 用ASP.NET建立一个在线RSS新闻聚合器(3)
  2. UNIQUE和PRIMARY 约束的区别
  3. 计算机数字信号原理,计算机网络通信原理数字信号的基带传输.ppt
  4. Markdown 工程师也不简单:如何写一个高逼格 README
  5. Swoole 2019 :化繁为简、破茧成蝶
  6. 妲己机器人怎么升级固件_OnRobot新增爱普生川崎机器人套件、HEX固件升级
  7. POJ3155 Hard Life
  8. 数据库索引失效的一些场景
  9. ssm(spring+spring mvc+mybatis+maven)高仿bilibili视频网站项目实例
  10. Asprise OCR v4.0 64位破解...仅供学习使用
  11. WLT8016:模组通信调试
  12. VR养狗,养的是寂寞还是潮流?
  13. IDEA 不检查语法错误问题
  14. Qt编写自定义控件56-波浪曲线
  15. SUG 180 Inversions(树状数组+离散化)
  16. R | failed to load cairo DLL
  17. 2023年全国最新机动车签字授权人精选真题及答案14
  18. php 时间戳 最大,PHP中大于2038年时间戳的问题处理
  19. 北京邮电/北京航空航天大学上机题目
  20. 嵌入式系统概述1-嵌入式系统定义、特点和发展历程

热门文章

  1. DataCastle[猫狗大战]冠军——Kuhung 思路及代码
  2. [CTO札记]猜到用户意图作出的推荐,被接受度很高
  3. FFmpeg常用命令大全,并简单封装
  4. python爬虫获取强智科技教务系统学科成绩(模拟登录+成绩获取)
  5. TraceRoute(tracert)实现原理
  6. amlogic 常用命令汇总
  7. 电子台账:模板制作之二——行过滤(垂直过滤)
  8. 严格对角化(Exact diagonalization)介绍
  9. Flex3 带复选框的树状下拉框
  10. 股票基金模拟交易日志5