ITPub博客

首页 > Linux操作系统 > Linux操作系统 > 为何要重建索引 index

为何要重建索引 index

原创 Linux操作系统 作者:306261655 时间:2012-06-06 15:17:32 0 删除 编辑

如果索引因为某些原因无效或者因为很长时间没有维护而产生过多的索引碎片(Index Fragment),需要通过重建索引来消除索引碎片。何时需

 

要重建索引,可以利用下面的过程进行判断。

   查询数据库中有哪些索引。

SQL>SELECT OWNER,INDEX_NAME FROM user_indexes;

SQL语句的执行结果是:

 

INDEX_NAME                     TABLE_OWNER                    TABLE_NAME

------------------------------ ------------------------------ ----------------------------------------

I_ID_SAMLLTABLE                SCOTT                          SMALLTABLE

I_ID_BIGTABLE                  SCOTT                          BIGTABLE

PK_EMP                         SCOTT                          EMP

PK_DEPT                        SCOTT                          DEPT

 

本文将以索引I_ID_BIGTABLE为例。

   对索引INDF5进行分析。

SQL> ANALYZE index I_ID_BIGTABLE VALIDATE STRUCTURE;

Index analyzed

   从视图INDEX_STATS中获得索引I_ID_BIGTABLE的统计信息。

SQL>SELECT HEIGHT,(DEL_LF_ROWS_LEN/LF_ROWS_LEN)*100 FROM INDEX_STATS WHERE NAME='I_ID_BIGTABLE';

SQL语句的执行结果是:

 HEIGHT (DEL_LF_ROWS_LEN/LF_ROWS_LEN)*

---------- ------------------------------

        1        10.1

其中,字典INDEX_STATS表示存放索引的统计信息;列DEL_LF_ROWS_LEN表示索引删除行数;列LF_ROWS_LEN表示索引总行数;列HEIGHT表示二叉树

 

中从根块到叶块的层次(深度)。

如果满足下面其中一个条件,则要考虑重建索引:

(DEL_LF_ROWS_LEN/LF_ROWS_LEN)*100的值大于20

HEIGHT的值大于4(说明二叉树的层次太多)

   使用ALTER INDEX ... REBUILD命令重建索引I_ID_BIGTABLE。

SQL> ALTER INDEX I_ID_BIGTABLE REBUILD;

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/25794484/viewspace-732055/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论

注册时间:2012-06-06

  • 博文量
    5
  • 访问量
    7472