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

 更新时间:2017年11月07日 08:43:19   作者:gjf281  
这篇文章主要给大家介绍了关于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单个字段多记录拼接方式

    Oracle单个字段多记录拼接方式

    这篇文章主要介绍了Oracle单个字段多记录拼接方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-07-07
  • Oracle中BLOB、CLOB的读取和写入方式

    Oracle中BLOB、CLOB的读取和写入方式

    Oracle数据库中,大类型字段(LOB)用于存储大量数据,包括文本、图像、视频等,主要类型有CLOB、BLOB、NCLOB和BFILE,CLOB用于存储大段文本,BLOB用于存储二进制数据,NCLOB适用于多国语言文本,而BFILE存储外部文件的引用
    2024-10-10
  • 详解oracle分页查询的基础原理

    详解oracle分页查询的基础原理

    这篇文章主要介绍了详解oracle分页查询的原理,从实例测试数据具体分析了实现方式,一起来参考下。
    2017-12-12
  • Oracle数据库如何获取多条结果集中的第一条或某一条

    Oracle数据库如何获取多条结果集中的第一条或某一条

    Oracle从多条符合条件的记录中选择一条这个需求相信大家应该都遇到过,这篇文章主要给大家介绍了关于Oracle数据库如何获取多条结果集中的第一条或某一条的相关资料,需要的朋友可以参考下
    2023-03-03
  • 解决oracle用户连接失败的解决方法

    解决oracle用户连接失败的解决方法

    oracle用户连接失败的问题着实让我们头疼,下面就为您介绍oracle用户连接失败的解决方法,希望对您学习oracle用户连接方面能有所帮助。
    2010-12-12
  • Oracle与SQL Server在企业应用的比较

    Oracle与SQL Server在企业应用的比较

    Oracle与SQL Server在企业应用的比较...
    2007-03-03
  • oracle更新xml节点问题的一些细节

    oracle更新xml节点问题的一些细节

    本节主要介绍了oracle更新xml节点问题的一些细节,需要的朋友可以参考下
    2014-08-08
  • Oracle中实现一次插入多条数据详细代码举例

    Oracle中实现一次插入多条数据详细代码举例

    公司的项目,有个功能每次使用需要向数据库插入很多数据,这里给大家总结下,这篇文章主要给大家介绍了Oracle中实现一次插入多条数据的相关资料,文中通过图文及代码介绍的非常详细,需要的朋友可以参考下
    2024-06-06
  • 解决Oracle模拟事务提交、表锁,处理表锁问题

    解决Oracle模拟事务提交、表锁,处理表锁问题

    这篇文章主要介绍了Oracle模拟事务提交、表锁,处理表锁问题,通过可视化工具navicat执行插入语句,发现虽然我们设置了不自动提交,这里还是插入成功了,这里给大家介绍下手动提交事务流程,需要的朋友可以参考下
    2022-09-09
  • 解决PL/SQL修改Oracle存储过程编译就卡死的问题

    解决PL/SQL修改Oracle存储过程编译就卡死的问题

    这篇文章主要介绍了PL/SQL修改Oracle存储过程编译就卡死,本文给大家分享问题原因及解决方法,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-01-01

最新评论