Oracle如何通过执行计划查看查询语句是否使用索引

 更新时间:2023年07月29日 09:43:02   作者:王绍桦  
这篇文章主要介绍了Oracle如何通过执行计划查看查询语句是否使用索引问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

1.生成执行计划

explain plan for
select * from t_call_records where t_bjhm='123456'

备注:

explain plan for后面为要生成执行计划的查询语句

2.查看执行计划结果

select * from table(dbms_xplan.display)

 

如上图所示:

TABLE ACCESS FULL为全表扫描;

为t_bjhm列加上索引后生成执行计划并查看结果:

  

如上图所示:

index range scan为索引范围扫描;

几种常见的索引类型扫描

  • 第一种:index unique  scan

索引唯一扫描,当可以优化器发现某个查询条件可以利用到主键、唯一键、具有外键约束的列,或者只是访问其中某行索引所在的数据的时候,优化器会选择这种扫描类型。

  • 第二种:index range scan

索引范围扫描,当优化器发现在UNIQUE列上使用了大于、小于、大于等于、小于等于以及BETWEEN等就会使用范围扫描,在组合列上只使用部分进行查询,导致查询出多行数据。

对非唯一的索引列上进行任何活动都会使用index range scan

  • 第三种:index full scan

全索引扫描,如果要查询的数据可以全部从索引中获取,则使用全索引扫描。

  • 第四种:index fast full scan

索引快速扫描,扫描索引中的全部的数据块,与全索引扫描的方式基本上类似。

两者之间的明显的区别是,索引快速扫描对查询的数据不进行排序,数据返回的时候不是排序的。

“在这种存取方法中,可以使用多块读功能,也可以使用并行读入,从而得到最大的吞吐量和缩短执行时间”。

order by、group by使用索引的前提条件

1.order by、group by中所有的列必须包含在相同的索引中并保持在索引中的排列顺序;

2.order by、group by中所有的列必须定义为非空

不走索引的几种情况

1.where子句中使用 is null 和 is not null

2.where子句中使用函数

3.使用like ‘%T’ 进行模糊查询

4.where子句中使用不等于操作(包括:<>, !=, not colum >= ?, not colum <= ? ,可以使用or代替)

5.比较不匹配数据类型,例如:select * from tablewhere jlbh = 1;jlbh为varchar2类型字段

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Oracle实现分页查询的SQL语法汇总

    Oracle实现分页查询的SQL语法汇总

    这篇文章主要介绍了Oracle实现分页查询的SQL语法,非常实用的功能,需要的朋友可以参考下
    2014-08-08
  • Oracle数据库使用 listagg去重删除重复数据的方法汇总

    Oracle数据库使用 listagg去重删除重复数据的方法汇总

    文章介绍了在Oracle数据库中使用LISTAGG和XMLAGG函数进行字符串聚合并去重的方法,包括去重聚合、使用XML解析和CLOB类型处理大字符串、以及根据具体需求选择合适的方法,感兴趣的朋友跟随小编一起看看吧
    2025-01-01
  • ORACLE数据库中Rownum用法详解

    ORACLE数据库中Rownum用法详解

    这篇文章主要介绍了ORACLE数据库中ROWNUM用法详解,对于rownum来说它是oracle系统顺序分配为从查询返回的行的编号,且rownum不能以任何表的名称作为前缀,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • oracle 查询当天数据的sql条件写法

    oracle 查询当天数据的sql条件写法

    这篇文章主要介绍了oracle 查询当天数据的sql条件写法,需要的朋友可以参考下
    2017-04-04
  • Oracle数据库查看锁表语句和解锁的方法示例

    Oracle数据库查看锁表语句和解锁的方法示例

    在DBA的日常工作中,经常遇到为Oracle用户解锁的操作,这篇文章主要给大家介绍了关于Oracle数据库查看锁表语句和解锁的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2023-10-10
  • ORACLE 自动提交问题

    ORACLE 自动提交问题

    通过PL/SQL DEVELOPER向数据库中的某个表中插入一定量的数据,通过select 语句可以看到已经插入到表中,然而诡异的是通过程序却无法查询到新插入的数据。
    2009-06-06
  • Oralce中VARCHAR2()与NVARCHAR2()的区别介绍

    Oralce中VARCHAR2()与NVARCHAR2()的区别介绍

    这篇文章主要给大家详细介绍了关于Oralce中VARCHAR2()与NVARCHAR2()的区别,文中先通过翻译官方的介绍进行区别总结,然后由一个实战示例代码进行演示,相信对大家的理解会很有帮助,有需要的朋友们下面来跟着小编一起看看吧。
    2016-12-12
  • Oracle中dblink的实际应用示例详解

    Oracle中dblink的实际应用示例详解

    DBLink的作用是在局域网内,通过一台服务器上面的数据库访问另外一台服务器上面数据库的功能。下面这篇文章主要给大家介绍了关于Oracle中dblink实际应用的相关资料,文中通过示例代码介绍的非常详细,需要的朋友们下面来一起看看吧。
    2017-09-09
  • Oracle to_char函数的使用方法

    Oracle to_char函数的使用方法

    在Oracle数据库中,to_char函数是我们最常用的函数之一,下文对to_char函数的应用作了详细的介绍,如果您感兴趣的话,不妨一看
    2014-08-08
  • 详解Oracle的sqlldr理论

    详解Oracle的sqlldr理论

    这篇文章主要介绍了详解Oracle的sqlldr理论,SQL*LOADER是ORACLE的数据加载工具,通常用来将操作系统文件(数据)迁移到ORACLE数据库中,SQL*LOADER是大型数据仓库选择使用的加载方法,因为它提供了最快速的途径(DIRECT,PARALLEL),需要的朋友可以参考下
    2023-07-07

最新评论