科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道Oracle8i数据库中索引的维护

Oracle8i数据库中索引的维护

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

本文只讨论Oracle中最常见的索引,即是B-tree索引。本文中涉及的数据库版本是Oracle8i。   一. 查看系统表中的用户索引   在Oracle中,SYSTEM表是安装数据库时自动建立的,它包含数据库的全部数据字典。

作者:中国IT实验室 来源:中国IT实验室 2007年10月11日

关键字: ORACLE

  • 评论
  • 分享微博
  • 分享邮件

在本页阅读全文(共4页)

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

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

  set linesize 120
  col "OWNER" format a20
  col "INDEX" format a30
  col "TABLE" format a30
  col "TABLESPACE" format a30
  select
  i.owner "OWNER",
  i.index_name "INDEX",
  t.table_name "TABLE",
  i.tablespace_name "TABLESPACE"
  from
  dba_indexes i,
  dba_tables t
  where i.owner=t.owner
  and i.table_name=t.table_name
  and i.tablespace_name=t.tablespace_name
  and i.owner not in ('SYS','SYSTEM')
  /

  第三,查看数据表空间里有哪些索引

  用户的默认表空间应该不是SYSTEM表空间,而是数据表空间。在建立索引时,如果不指定相应的索引表空间名,那么,该索引就会建立在数据表空间中。这是程序员经常忽略的一个问题。应该在建索引时,明确的指明相应的索引表空间。

  col segment_name format a30
  select
  owner,
  segment_name,
  sum(bytes)
  from dba_segments
  where tablespace_name='数据表空间名'
  and segment_type='INDEX'
  group by owner,segment_name
  /

  第四,查看哪个索引被扩展了超过10次

  随着表记录的增加,相应的索引也要增加。如果一个索引的next extent值设置不合理(太小),索引段的扩展变得很频繁。索引的extent太多,检索时的速度和效率就会降低。

  set linesize 100
  col owner format a10
  col segment_name format a30
  col tablespace_name format a30
  select
  count(*),
  owner,
  segment_name,
  tablespace_name
  from dba_extents
  where segment_type='INDEX'
  and owner not in ('SYS','SYSTEM')
  group by owner,segment_name,tablespace_name
  having count(*) >10
  order by count(*) desc
  /

  (2)找出需要重建的索引后,需要确定索引的大小,以设置合理的索引存储参数。

  set linesize 120
  col "INDEX" format a30
  col "TABLESPACE" format a20
  select
  owner "OWNER",
  segment_name "INDEX",
  tablespace_name "TABLESPACE",
  bytes "BYTES/COUNT",
  sum(bytes) "TOTAL BYTES",
  round(sum(bytes)/(1024*1024),0) "TOTAL M",
  count(bytes) "TOTAL COUNT"
  from dba_extents
  where segment_type='INDEX'
  and segment_name in
  (
  '索引名1',
  '索引名2',
  ......
  )
  group by owner,segment_name,segment_type,tablespace_name,bytes
  order by owner,segment_name
  /

 

查看本文来源

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章