数据库学习(三)---Oracle通过执行计划查看查询语句是否使用索引

1、生成执行计划

explain plan for
select * from SYS_USER where USERNAME='张三';

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

2、查看执行计划结果

select * from table(dbms_xplan.display);

在这里插入图片描述
如上图所示,TABLE ACCESS FULL为全表扫描;

为USERNAME列加上索引后生成执行计划并查看结果:
在这里插入图片描述
如上图所示,index range scan为索引范围扫描。

3、几种常见的索引类型扫描:

第一种: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中所有的列必须定义为非空

4、不走索引的几种情况:

  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类型字段

5、总结:

  1. 在索引前后创建的数据都可以经过索引查询
  2. 我之前在做一个用户表查询,把10000条数据导出来后,添加索引,再把10000条数据导进去,发现索引不生效,查了半天发现,原始表中有数据没有清干净,和10000条数据中的某些数据有冲突,把表清干净之后再次导入索引就可以生效了。
  3. 索引第二天就会失效这个问题还不知道怎么解决
  • 1
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值