您现在的位置是:网站首页> 编程资料编程资料
Oracle使用强制索引的方法与注意事项_oracle_
2023-05-27
448人已围观
简介 Oracle使用强制索引的方法与注意事项_oracle_
Oracle使用强制索引
在一些场景下,可能ORACLE不会自动走索引,这时候,如果对业务清晰,可以尝试使用强制索引,测试查询语句的性能。
以EMP表为例:
先在EMP表中建立唯一索引,如图。

普通搜索:
SELECT * FROM EMP T
查看执行计划:

可以看到,是走的全表扫描。
使用强制索引,在SELECT 后面加上/*.......*/ 中间加上索引的属性,代码如下:
SELECT /*+index(t pk_emp)*/* FROM EMP T --强制索引,/*.....*/第一个星星后不能有空格,里边内容结构为:加号index(表名 空格 索引名)。 --如果表用了别名,注释里的表也要使用别名。
可以看到,这是走的是索引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的执行效率
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
您可能感兴趣的文章:
相关内容
- Oracle dbca时报:ORA-12547: TNS:lost contact错误的解决_oracle_
- Oracle结合Mybatis实现取表TOP 10条数据_oracle_
- oracle中decode函数的使用方法示例_oracle_
- Oracle中游标Cursor基本用法详解_oracle_
- Oracle数据库中ora-12899错误的解决方法_oracle_
- Oracle实例启动时报错:ORA-32004的解决方法_oracle_
- Oracle参数设置教程之set和reset的实用案例_oracle_
- oracle 12c因误删pdb数据文件导致整个数据库打不开的解决方法_oracle_
- Oracle监听日志定期清理_oracle_
- Oracle AWR(自动工作量资料档案库)的管理与维护详解_oracle_
