oracle hint 强制索引(转)

oracle

1.建议建立一个以paytime,id,cost的复合索引。光是在paytime上建立索引会产生很多随机读。

2.就算建立了索引,如果你查询的数据量很大的话,也不一定会用索引,有时候全表扫描速度比索引扫描要快!(官方文档上好像说的是大概10%,就是如果你查询的数据占到总数据的10%,全表扫描比索引快)。

3.建复合索引语句如下(建议去

Oracle强制索引_oracle

看看官方文档,建索引有很多参数,而且每个版本的​​ORACLE​​也不一定一样):

CREATE ​​INDEX​​​TEST_​​index​​​​ON​​​C​​ON​​SUME_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表中建立唯一索引,如图。

Oracle强制索引_查询语句_02

普通搜索:

SELECT * FROM EMP T

查看执行计划:

Oracle强制索引_查询语句_03

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

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

SELECT /*+index(t pk_emp)*/* FROM EMP T   

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

 

Oracle强制索引_查询语句_04

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

测试:

Oracle强制索引_oracle_05

Oracle强制索引_查询语句_06