WEB开发网
开发学院数据库Oracle Oracle数据库中索引的维护 阅读

Oracle数据库中索引的维护

 2006-08-05 11:58:25 来源:WEB开发网   
核心提示: (1)利用验证索引命令对索引进行验证,这将有价值的索引信息填入index_stats表,Oracle数据库中索引的维护(4),validate index 用户名.索引名/(2)查询index_stats表以确定索引中删除的、未填满的叶子行的百分比,selectname,del_lf_ro

(1)利用验证索引命令对索引进行验证。

这将有价值的索引信息填入index_stats表。

validate index 用户名.索引名
/

(2)查询index_stats表以确定索引中删除的、未填满的叶子行的百分比。

select
name,
del_lf_rows,
lf_rows,
round((del_lf_rows/(lf_rows+0.0000000001))*100) "Frag Percent"
from index_stats
/

(3)如果索引的叶子行的碎片超过10%,考虑对索引进行重建。

alter index 用户名.索引名 rebuild
tablespace 表空间名
storage(initial 初始值 next 扩展值)
nologging
/

(4)如果出于空间或其他考虑,不能重建索引,可以整理索引。

alter index用户名.索引名 coalesce
/

(5)清除分析信息

analyze index 用户名.索引名
delete statistics
/
五. 重建索引

(1)检查需要重建的索引。

根据以下几方面进行检查,确定需要重建的索引。

第一,查看SYSTEM表空间中的用户索引。

为了避免数据字典的碎片出现,要尽量避免在SYSTEM表空间出现用户的表和索引。

select index_name
from dba_indexes
where tablespace_name='SYSTEM'
and owner not in ('SYS','SYSTEM')
/

第二,确保用户的表和索引不在同一表空间内。

表和索引对象的第一个规则是把表和索引分离。把表和相应的索引建立在不同的表空间中,最好在不同的磁盘上。这样可以避免在数据管理和查询时出现的许多I/O冲突。

上一页  1 2 3 4 5 6  下一页

Tags:Oracle 数据库 索引

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接