设为首页 收藏本站
查看: 1143|回复: 1

[经验分享] Oracle索引监控,重建,不可见

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2013-12-6 09:21:07 | 显示全部楼层 |阅读模式
   简单总结了下 Oracle索引管理的一些东东。命令都很简单,但要注意下我列出的一些功能特性,执行后果,常见问题。
   以及一点点小技巧。
   一. 如何监控索引
   二 10g失效及重建索引及常见问题
   三. 11g的索引不可见特性

一.监控索引
1.  从DBA用户下执行下面代码,   
     alter index DEMO.  IDX_TEST monitoring usage;  
2. 以索引或表所属用户登录后在  v$object_usage 查看监控结果。
   SELECT * FROM v$object_usage;
3. 取消监控
   alter index DEMO.IDX_TEST nomonitoring usage;

  技巧1:
  可通过修改下面代码,批量执行监控和取消监控动作。   
set serveroutput on  
declare  
  v_owner varchar2(20) := 'DEMO';  -- 指定要监控哪个用户下的表  
  v_table varchar2(60) := '%';            -- 依表名过滤, '%' 代表为所有可访问表  
  v_type  varchar2(15) := 'monitoring'; -- 值 monitoring / nomonitoring 分别对应监控和取消监控  
  --v_cmd   varchar2(255);  
begin        
  -- 如使用表所属用户登录,将dba_indexes改为下面这个user_indexes 为准的即可。  
   -- select table_owner||'.'||index_name as idxname   
   --   from user_indexes where  table_name like v_table  
   for i in (select table_owner||'.'||index_name as idxname   
              from dba_indexes     
              where owner = v_owner  and table_name like v_table  
             ) loop  
     execute immediate 'alter index '||i.idxname||' '||v_type||' usage';      
     -- v_cmd := 'execute immediate ''alter index '||i.idxname||' '||v_type||' usage''';        
     -- dbms_output.put_line(v_cmd);        
  end loop;  
end;  
技巧2:
    你会发现,虽然取消索引监控,或者很久之前有一个索引被执行过,这些索引在v$object_usage 视图中
    仍能查到,很不爽。
         执行    delete from object_usage; 即可清理掉这些。

二.10g失效及重建索引及常见问题

1. 使用索引失效
   命令:   alter index  idx_test2_id unusable;
   索引失效后:
        a. 索引并不会被删掉,即还会占用数据库空间.
        b. 可在索引视图中查到状态为 "UNUSABLE"。
        c. 表不会再与这个索引做同步更新。
        d. 执行计划不会再使用这个索引
        c. 对表的影响:
           对表insert 会出现 ORA-01502错误,提示 "这类索引的分区处于不可用状态"
           对表update正常。
           对表 select  正常。

      --查询所有失效索引
      select a.status,a.* from dba_indexes a where status = 'UNUSABLE'
2.  通过重建索引,使用索引重新可用。
       alter index  idx_test2_id rebuild;
       重建尽量不要在业务高峰期做,大表将会花很多时间。
       对于唯一索引的重建,有可能报ORA-01452,说明列有重复值存在,不能重建这个索引。

注意事项:
    除了手工执行命令使索引失效外。 还会有其它原因造成的一些索引自动失效。
    最常见的是更改了表的表空间,则此表相关的所有索引全自动失效。
      -- 更改表空间
      alter table 表名 move tablespace 表空间;
   另一种常见情况是10g的数据库自动采集程序造成的索引失效。
     索引的失效有时后果是很严重的,所以DBA要经常检查索引状态,特别是对于一些关键索引。

三.11g的索引不可见特性
    1. 索引变为不可见
        alter index idx_test2_id invisible;
          不可见后:
            a. 照样表会与这个索引同步更新。
            b. 执行计划不会再使用这个索引
            c. 对表的影响:
                  除了执行计划看不到外,索引的约束力仍在。
    2. 使 索引可见
        alter index idx_test2_id  visible;
        比起重建索引,省事多了,因为一直有在同步更新。

另外,在项目开发和维护中,如何正确使用索引,有兴趣的话可以看下我写的这篇:  DBA写给开发的索引经验



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-11232-1-1.html 上篇帖子: ORA-01017: invalid username/password; logon denied 下篇帖子: Oracle还原RMAN初始配置 Oracle 监控

尚未签到

发表于 2014-1-5 02:47:37 | 显示全部楼层
要怎么证明,你的亲吻真的残忍.

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表