SQL是Structured Query Language(结构化查询语言)的缩写。SQL是专为数据库而建立的操作命令集,是一种功能齐全的数据库语言。在使用它时,只需要发出“做什么”的命令,“怎么做”是不用使用者考虑的。SQL功能强大、简单易学、使用方便,已经成为了数据库操作的基础,并且现在几乎所有的数据库均支持SQL。 本文主要给大家介绍了关于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的执行效率 相关推荐: mysql与oracle数据库停止与启动的批处理文件 如何向MySQL数据库或者Oracle或导入表格文件 oracle 用HINT方式强制索引 以上就是详解Oracle使用强制索引的方法与注意事项的详细内容,更多请关注php中文网其它相关文章!
学习教程快速掌握从入门到精通的SQL知识。
|