当前位置:  数据库>oracle

Oracle 不使用索引的原因有哪些?

    来源: 互联网  发布时间:2017-06-02

    本文导语: 今天开始总结一下Oracle不使用索引的原因有哪些。一边学习一边做笔记。 第一种:行数存在差异。 在视图user_tables存在一个num_rows字段,该字段是记录在统计信息收集后所对应对象的行数,在user_tab_columns视图中存在一个num_distinc...

今天开始总结一下Oracle不使用索引的原因有哪些。一边学习一边做笔记。

第一种:行数存在差异。

在视图user_tables存在一个num_rows字段,该字段是记录在统计信息收集后所对应对象的行数,在user_tab_columns视图中存在一个num_distinct字段,该字段记录每个字段内不同数值的个数。oracle认为当num_distinct越接近num_rows的时候索引的选择性越好,那么在执行查询的时候越容易使用索引。

第二种:聚簇因子:

什么是聚簇因子?

聚簇因子是衡量索引列数据顺序与表字段数据顺序相似性的一个值。我们都知道在创建的表中一般都是堆表,也就是数据在表中存储是无续的,那么为了更加快速的访问数据,我们通常使用索引进行数据访问,这时候没个索引都有一个聚簇因子,聚簇因子越接近对象的块数,那么选择性越好,越接近表的行数那么选择性越差。

之前听到有个朋友曾经提到这么一个问题“为什么我在测试环境查询一个数据很快和在生产环境查询数据怎么这么慢呢?表结构都一样的,数据也是一样的。”。那么不妨看看聚簇因子是多少。

聚簇因子的查看是从user_ind_statistics视图中: CLUSTERING_FACTOR 表示的。看一下官方介绍:

Indicates the amount of order of the rows in the table based on the values of the index.

  • If the value is near the number of blocks, then the table is very well ordered. In this case, the index entries in a single leaf block tend to point to rows in the same data blocks.

  • If the value is near the number of rows, then the table is very randomly ordered. In this case, it is unlikely that index entries in the same leaf block point to rows in the same data blocks.

往往聚簇因子的大小和数据获取的I/o存在一定的相似性。如果聚簇因子大,那么相对的物理或是逻辑(一般是)i/o开销很大,也就是块被频繁反复读取,一致数据获取很慢。

长查询的视图有dba_ind_statistics和dba_tab_statistics

第三种:使用不等条件:

当使用在进行查询数据的时候使用不等条件,那么oracle任务这个符号会需要读取大部分的数据块,那么就会跳过使用索引。eg:

SQL> select index_name,table_name,column_name from user_ind_columns where table_name='EMP';

INDEX_NAME                    TABLE_NAME                    COLUMN_NAME
------------------------------ ------------------------------ ----------------------------------------
EMP_IDX1                      EMP                            DEPTNO
EMP_IDX1                      EMP                            EMPNO

SQL> select * from emp;

    EMPNO ENAME      JOB              MGR HIREDATE        SAL      COMM    DEPTNO
---------- ---------- --------- ---------- --------- ---------- ---------- ----------
      7782 CLARK      MANAGER        7839 09-JUN-81      2450                    10
      7839 KING      PRESIDENT            17-NOV-81      5000                    10
      7934 MILLER    CLERK          7782 23-JAN-82      1300                    10
      7369 SMITH      CLERK          7902 17-DEC-80        800                    20
      7566 JONES      MANAGER        7839 02-APR-81      2975                    20
      7788 SCOTT      ANALYST        7566 19-APR-87      3000                    20
      7876 ADAMS      CLERK          7788 23-MAY-87      1100                    20
      7902 FORD      ANALYST        7566 03-DEC-81      3000                    20
      7499 ALLEN      SALESMAN        7698 20-FEB-81      1600        300        30
      7521 WARD      SALESMAN        7698 22-FEB-81      1250        500        30
      7654 MARTIN    SALESMAN        7698 28-SEP-81      1250      1400        30
      7698 BLAKE      MANAGER        7839 01-MAY-81      2850                    30
      7844 TURNER    SALESMAN        7698 08-SEP-81      1500          0        30
      7900 JAMES      CLERK          7698 03-DEC-81        950                    30

14 rows selected.

SQL> set autotrace trace exp
SQL> select * from emp where empno7900;

Execution Plan
----------------------------------------------------------
Plan hash value: 822536733

--------------------------------------------------------------------------------------------
| Id  | Operation          | Name | Rows  | Bytes | Cost (%CPU)| Time    | Pstart| Pstop |
--------------------------------------------------------------------------------------------
|  0 | SELECT STATEMENT    |      |    13 |  494 |    14  (0)| 00:00:01 |      |      |
|  1 |  PARTITION RANGE ALL|      |    13 |  494 |    14  (0)| 00:00:01 |    1 |    4 |
|*  2 |  TABLE ACCESS FULL | EMP  |    13 |  494 |    14  (0)| 00:00:01 |    1 |    4 |
--------------------------------------------------------------------------------------------

Predicate Information (identified by operation id):
---------------------------------------------------

  2 - filter("EMPNO"7900)

SQL> select /*+index(emp EMP_IDX1)*/ * from emp where empno7900;

Execution Plan
----------------------------------------------------------
Plan hash value: 257372123

---------------------------------------------------------------------------------------------------------------
| Id  | Operation                          | Name    | Rows  | Bytes | Cost (%CPU)| Time    | Pstart| Pstop |
---------------------------------------------------------------------------------------------------------------
|  0 | SELECT STATEMENT                  |          |    13 |  494 |    6  (0)| 00:00:01 |      |      |
|  1 |  PARTITION RANGE ALL              |          |    13 |  494 |    6  (0)| 00:00:01 |    1 |    4 |
|  2 |  TABLE ACCESS BY LOCAL INDEX ROWID| EMP      |    13 |  494 |    6  (0)| 00:00:01 |    1 |    4 |
|*  3 |    INDEX FULL SCAN                | EMP_IDX1 |    13 |      |    3  (0)| 00:00:01 |    1 |    4 |
---------------------------------------------------------------------------------------------------------------

Predicate Information (identified by operation id):
---------------------------------------------------

  3 - filter("EMPNO"7900)

SQL>


    
 
 

您可能感兴趣的文章:

  • Oracle与Mysql主键、索引及分页的区别小结
  • 从Oracle的约束到索引
  • Oracle 9i轻松取得建表和索引的DDL语句
  • Oracle9i取得建表和索引的DDL语句
  • oracle10g全文索引自动同步语句使用方法
  • Oracle建立二进制文件索引的方法
  • 在Oracle 10g中如何获得索引的专家建议
  • Oracle全文索引设置
  • 用Oracle 9i全索引扫描快速访问数据
  • Oracle中如何把表和索引放在不同的表空间里
  • Oracle索引存储关系到数据库的运行效率
  • Oracle索引聚簇表的数据加载
  • 在Oracle中监控和跟踪索引使用情况
  • Oracle中SQL语句连接字符串的符号使用介绍 iis7站长之家
  • Oracle中检查是否需要重构索引的sql
  • 轻松取得Oracle 9i建表和索引DDL语句
  • 深度揭露Oracle索引使用中的限制
  • Oracle索引(B*tree与Bitmap)的学习总结
  • oracle 索引不能使用深入解析
  • SQL Server和Oracle数据库索引介绍
  • Oracle 11G SELinux原因启动失败的解决办法
  • linux as3 _weblogic8_oracle系统访问50万/日,常常ping不通,分析原因
  • jsp访问oracle超出打开游标的最大数是什么原因?急,在线给分。
  • ORACLE EXP不能导出空表的原因分析及解决方法
  • 有时Oracle不用索引来查找数据的原因
  • DBLINK在Linux平台出现的ORACLE.EXE原因分析
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • linux下安装oracle后使用命令行启动的方法 linux启动oracle
  • Oracle9i 9.0.1的JDBC Drivers 可以给Oracle 8.0.5使用马?
  • Suse linux使用oracle问题
  • 请问:在使用oracle数据库作开发时,是使用pro*c作开发好些,还是使用库函数如oci等好一些啊?或者它们有什么区别或者优缺点啊?
  • jbuilder中使用oracle的问题
  • 求redhat linux 9.0下可以使用的oracle 10g或9i,还有redhat linux 9.0下可以使用的eclipse下载地址
  • Oracle事务!使用游标提交过程
  • 在Jbuilder7下,使用DbPilot.exe连接oracle,报错!请教高手!
  • AIX 64位系统上如何使用32位OCI oracle driver
  • Oracle中SQL语句连接字符串的符号使用介绍
  • 使用X manager连接oracle数据库的步骤
  • C++使用OCCI连Oracle10g的错误
  • 使用工具 plsqldev将Excel导入Oracle数据库
  • Linux下Oracle的sqlplus使用光标上下左右方法
  • Oracle 数据 使用游标
  • oracle使用sql脚本生成csv文件案例学习
  • ORACLE 修改表结构 之ALTER CONSTAINTS的使用
  • Linux中Oracle使用相关知识集锦
  • Oracle密码文件的使用和维护第1/3页
  • Oracle 触发器的使用小结
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle 10g和Oracle 11g网格技术介绍


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,