zl程序教程

您现在的位置是:首页 >  数据库

当前栏目

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

Oracle方法索引 使用 注意事项 强制
2023-06-13 09:19:16 时间

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使用强制索引

在一些场景下,可能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的执行效率

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


我想要获取技术服务或软件
服务范围:MySQL、ORACLE、SQLSERVER、MongoDB、PostgreSQL 、程序问题
服务方式:远程服务、电话支持、现场服务,沟通指定方式服务
技术标签:数据恢复、安装配置、数据迁移、集群容灾、异常处理、其它问题

本站部分文章参考或来源于网络,如有侵权请联系站长。
数据库远程运维 Oracle使用强制索引的方法与注意事项