Chinaunix首页 | 论坛 | 博客
  • 博客访问: 6536415
  • 博文数量: 915
  • 博客积分: 17977
  • 博客等级: 上将
  • 技术积分: 8846
  • 用 户 组: 普通用户
  • 注册时间: 2005-08-26 09:59
个人简介

一个好老好老的老程序员了。

文章分类

全部博文(915)

文章存档

2022年(9)

2021年(13)

2020年(10)

2019年(40)

2018年(88)

2017年(130)

2015年(5)

2014年(12)

2013年(41)

2012年(36)

2011年(272)

2010年(1)

2009年(53)

2008年(65)

2007年(47)

2006年(81)

2005年(12)

分类: Oracle

2008-01-15 18:48:35

在ORACLE里按用户名重建索引的方法     CSDN Blog推出文章指数概念,文章指数是对Blog文章综合评分后推算出的,综合评分项分别是该文章的点击量,回复次数,被网摘收录数量,文章长度和文章类型;满分100,每月更新一次。


        ---------------------------------------------------------------------------
        SET ECHO      OFF;
        SET FEEDBACK  OFF;
        SET VERIFY    OFF;
        SET PAGESIZE  0;
        SET TERMOUT   ON;
        SET HEADING   OFF;
        ACCEPT username CHAR PROMPT 'Enter the index username: ';
        spool /oracle/rebuild_&username.sql;
       
        SELECT
                  'REM +-----------------------------------------------+' || chr(10) ||
                  'REM | INDEX NAME : ' || owner   || '.'
|| segment_name
                 || lpad('|', 33 - (length(owner) + length(segment_name)) )
                 || chr(10) ||
                  'REM | BYTES      : ' || bytes   
                 || lpad ('|', 34-(length(bytes)) ) || chr(10) ||
                  'REM | EXTENTS    : ' || extents
                 || lpad ('|', 34-(length(extents)) ) || chr(10) ||
                  'REM +-----------------------------------------------+' || chr(10) ||
          'ALTER INDEX ' || owner || '.'
|| segment_name || chr(10) ||
          'REBUILD ' || chr(10) ||
          'TABLESPACE ' || tablespace_name || chr(10) ||
          'STORAGE ( ' || chr(10) ||
          '  INITIAL     ' || initial_extent || chr(10) ||
          '  NEXT        ' || next_extent || chr(10) ||
          '  MINEXTENTS  ' || min_extents || chr(10) ||
          '  MAXEXTENTS  ' || max_extents || chr(10) ||
          '  PCTINCREASE ' || pct_increase || chr(10) ||
          ');' || chr(10) || chr(10)
        FROM   dba_segments
        WHERE  segment_type = 'INDEX'
          AND  owner='&username'
        ORDER BY owner, bytes DESC;
       
        spool off;

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

       
如果你用的是WINDOWS系统, 想改变输出文件的存放目录, 修改spool后面的路径成:
        spool c:\oracle\rebuild_&username.sql;

       
如果你只想对大于max_bytes的索引重建索引, 可以修改上面的SQL语句:       
       
AND  owner='&username' 后面加个限制条件 AND  bytes> &max_bytes

       
如果你想修改索引的存储参数, 在重建索引rebuild_&username.sql里改也可以.
       
比如把pctincrease不等于零的值改成是零.

       
如果你想把index从一个TABLESPACE转移到另外一个TABLESPACE,也可以修改其中的tablespace_name
阅读(4927) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~