三度网教程:是一个免费提供流行视频软件教程、在线学习分享的学习平台!

详细说明Oracle运用强制索引的方法与注意事项

时间:2022-10-18作者:未知来源:三度网教程人气:


SQL是Structured Query Language(结构化查询语言)的缩写。SQL是专为数据库而建立的操作命令集,是一种功能齐全的数据库语言。在使用它时,只需要发出“做什么”的命令,“怎么做”是不用使用者考虑的。SQL功能强大、简单易学、使用方便,已经成为了数据库操作的基础,并且现在几乎所有的数据库均支持SQL。
本文主要给大家介绍了关于Oracle使用强制索引的方法与注意事项,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。希望能帮助到大家。

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的执行效率

相关推荐:

mysql与oracle数据库停止与启动的批处理文件

如何向MySQL数据库或者Oracle或导入表格文件

oracle 用HINT方式强制索引

以上就是详解Oracle使用强制索引的方法与注意事项的详细内容,更多请关注php中文网其它相关文章!


学习教程快速掌握从入门到精通的SQL知识。

关键词:  详细说明Oracle运用强制索引的办法与注意事项





Copyright © 2012-2018 三度网教程(http://www.3du8.cn) .All Rights Reserved 网站地图 友情链接

免责声明:本站资源均来自互联网收集 如有侵犯到您利益的地方请及时联系管理删除,敬请见谅!

QQ:1006262270   邮箱:kfyvi376850063@126.com   手机版