Oracle强制索引
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强制索引相关推荐
- oracle 强制索引_当唯一索引遇见分布式数据库
这是Tank的第18篇文章 1 关于分片键 分布式数据库通过将表的数据打散,按一定规则将数据分布在多个独立的主机上,常见的策略如HASH.RANGE.LIST等分布方式.不考虑中间件的解决方案,在原生 ...
- oracle 强制索引 hint,oracle常用hint详解
相对而言ORACLE优化器已经非常智能,产生的执行计划也是最优的,但是ORACLE还是提供了一些hint供用户显示的控制执行计划,因为大千世界各种各样的业务都有,ORACLE优化器生成的执行计划并不一 ...
- oracle 强制索引 hint,ORACLE进阶之一:HINT
最近由于需要经常统计数据,需要经常用到hint,又不好意思每次都去麻烦DBA,所以在与DBA交流之后,整理了一份关于我们写ORACLE SQL语句时最常用到的hint使用方法: 另外,我们以前的流程都 ...
- oracle强制走索引_实验验证:Oracle聚簇因子对索引使用的影响
[引言] 本文基于如下文章进行的实验,讲述聚簇因子对SQL索引的影响. 链接如下: https://www.modb.pro/db/40283 一张表上有索引,sql在执行的时候却不走索引的原因有很多 ...
- oracle hint 强制索引
–用法 select /+index(表名(可用别名) 索引名称)/ –oracle hint 强制索引(只是建议oracle优化器走该索引,有该条语句时大概率会适应该索引,并不意味着oracle执行 ...
- oracle中强制走索引,Oracle数据库强制索引
当where子句对某一列使用函数时,除非利用这个简单的技术强制索引,否则Oracle优化器不能在查询中使用索引. 通常情况下,如果在WHERE子句中不使用诸如UPPER.REPLACE 或SUBSTR ...
- oracle加强制索引,Oracle中建立索引并强制优化器使用
当WHERE子句对某一列使用函数时,除非利用这个简单的技术强制索引,否则Oracle优化器不能在查询中使用索引. 通常情况下,如果在WHERE子句中不使用诸如UPPER.REPLACE 或SUBSTR ...
- MySQL force Index 强制索引概述
以下的文章主要介绍的是MySQL force Index 强制索引,以及其他的强制操作,其优先操作的具体操作步骤如下:我们以MySQL中常用的hint来进行详细的解析,如果你是经常使用Oracle的 ...
- MYSQL中常用的强制性操作(例如强制索引)
对于经常使用oracle的朋友可能知道,oracle的hint功能种类很多,对于优化sql语句提供了很多方法.同样,在mysql里,也有类似的hint功能. 其他强制操作,优先操作如下: mysql常 ...
最新文章
- 用ASP.NET建立一个在线RSS新闻聚合器(3)
- UNIQUE和PRIMARY 约束的区别
- 计算机数字信号原理,计算机网络通信原理数字信号的基带传输.ppt
- Markdown 工程师也不简单:如何写一个高逼格 README
- Swoole 2019 :化繁为简、破茧成蝶
- 妲己机器人怎么升级固件_OnRobot新增爱普生川崎机器人套件、HEX固件升级
- POJ3155 Hard Life
- 数据库索引失效的一些场景
- ssm(spring+spring mvc+mybatis+maven)高仿bilibili视频网站项目实例
- Asprise OCR v4.0 64位破解...仅供学习使用
- WLT8016:模组通信调试
- VR养狗,养的是寂寞还是潮流?
- IDEA 不检查语法错误问题
- Qt编写自定义控件56-波浪曲线
- SUG 180 Inversions(树状数组+离散化)
- R | failed to load cairo DLL
- 2023年全国最新机动车签字授权人精选真题及答案14
- php 时间戳 最大,PHP中大于2038年时间戳的问题处理
- 北京邮电/北京航空航天大学上机题目
- 嵌入式系统概述1-嵌入式系统定义、特点和发展历程