欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Oracle使用强制索引的方法与注意事项

程序员文章站 2022-03-16 20:17:28
oracle使用强制索引 在一些场景下,可能oracle不会自动走索引,这时候,如果对业务清晰,可以尝试使用强制索引,测试查询语句的性能。 以emp表为例: 先在em...

oracle使用强制索引

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

以emp表为例:

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

Oracle使用强制索引的方法与注意事项

普通搜索:

select * from emp t

查看执行计划:

Oracle使用强制索引的方法与注意事项

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

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

select /*+index(t pk_emp)*/* from emp t 

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

Oracle使用强制索引的方法与注意事项 

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

oracle使用强制索引注意事项

最近对oracle的sql索引生效条件进行了验证,发现如下规律,记录如下:

1、索引生效与记录的条数相关

      a、2016-01-01~2016-11-30 数据量402518,索引生效

      b、2016-01-01~2016-12-30 数据量444844,索引不生效

select 
 * 
from 
 t_mains 
where 
 date > to_date (--备注今天是2017-01-23 
  '2016-01-01', 
  'yyyy-mm-dd hh24:mi:ss' 
 ) 
and date < to_date ( 
 '2016-11-30', 
 'yyyy-mm-dd hh24:mi:ss' 
); 

2、t_mains已根据某个时间类型的字段进行分区,查询条件中如果能够精准定位到某个分区,可以提高sql的执行效率

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。