Oracle中检查是否需要重构索引的sql

前端之家收集整理的这篇文章主要介绍了Oracle中检查是否需要重构索引的sql前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

<div class="codetitle"><a style="CURSOR: pointer" data="98449" class="copybut" id="copybut98449" onclick="doCopy('code98449')"> 代码如下:

<div class="codebody" id="code98449">
SELECT
height,/Height of the B-Tree/
blocks,/ Blocks in the index segment /
name,/index name /
lf_rows,/ number of leaf rows in the index /
lf_blks,/ number of leaf blocks in the index /
del_lf_rows,/ number of deleted leaf rows in the index /
rows_per_key / average number of rows per distinct key /
blk_gets_per_access / consistent mode block reads (gets) /
FROM INDEX_STATS
WHERE NAME='INDEX_NAME';

<div class="codetitle"><a style="CURSOR: pointer" data="90163" class="copybut" id="copybut90163" onclick="doCopy('code90163')"> 代码如下:
<div class="codebody" id="code90163">
ANALYZE index INDEX_NAME VALIDATE STRUCTURE
HEIGHT:
This column refers to the height of the B-tree index,and it's usually at the 1,2,or 3 level.
If large inserts push the index height beyond a level of 4,it's time to rebuild,which flattens the B-tree. DEL_LF_ROWS:
This is the number of leaf nodes deleted due to the deletion of rows.
Oracle doesn't rebuild indexes automatically and,consequently,too many deleted leaf rows can lead to an unbalanced B-tree. BLK_GETS_PER_ACCESS:
You can look at the BLK_GETS_PER_ACCESS column to see how much logical I/O it takes to retrieve data from the index. If this row shows a double-digit number,you should probably start rebuilding the index.

猜你在找的Oracle相关文章