oracle数据库如何重建索引

  次阅读 作者:智能小宝 来源:互联网 2016-01-28 13:18 我要评论(0)

当索引的碎片过多时,会影响执行查询的速度,从而影响到我们的工作效率。这时候采取的最有利的措施莫过于重建索引了。本文主要介绍了Oracle数据库中检查索引碎片并重建索引的过程,接下来我们就开始介绍这一过程。

重建索引的步骤如下:

1. 确认基本信息

登入数据库,找到专门存放index的tablespace,并且这个tablespace下所有index的owner都是tax.将index专门存放在一个独立的tablespace,与数据表的tablespace分离,是常用的数据库设计方法。

2. 查找哪些index需要重建

通过anlyze index .... validate structure命令可以分析单个指定的index,并且将单个index 分析的结果存放到index_stats试图下。一般判断的依据是:

height >4 pct_used < 50% del_lf_rows / lf_rows +0.001 > 0.03 g)

3. google上下载了遍历所有index脚本

发现anlyze index .... validate structure只能填充单个index分析信息,于是google了下,从网上下了个Loop脚本,遍历索引空间下所有的索引名字,并且可以把所有index的分析信息存放到自己建立的一个用户表中。

4. anlyze index 锁定index

发现下载的脚本不好用,应为anlyzeindex在分析索引前要争取独占锁,锁住index,很明显有些index正在被应用系统的使用,所以运行anlyze失败。这里吸取的教训是,尽量晚上做这种事。但是本人比较喜欢准时回家,所以在语句中添加ExceptionHandler,抛出anlyze index执行失败的那些index 名称,使脚本正常运行完毕。并且根据打印到前台的indexname手动执行那些index分析。

5. 总结

虽然发现522个index中有160个符合上面的判断的依据。但是发现索引都不大,而那些拥有百万leaf的索引又没有符合上面的判断条件,所以结论是无需indexrebuild online. 没有啥碎片。

6.什么时候可以rebuild index呢?

rebuild indexonline,对那些有大量DML操作的大索引是有益的。可以每个月季度做一次针对较大索引的rebuild。通常哪怕rebuild indexonline也会造成I/O争用,所以有无online意义不大,可以放到3-5个晚上,分批执行rebuildindex,锁定index,不让用户用(没有用户等入的时候),并且加上paralle 8关键字,应为发现数据库服务器有8个cpu processors.

关于Oracle数据库检查索引碎片和重建索引的知识就介绍到这里,希望能够对您有所帮助。

本站文章信息来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • 无人驾驶汽车如何改变城市生活?听听他们怎么说

    无人驾驶汽车如何改变城市生活?听听他们怎么说

  • 韩春雨称已能重复实验结果 近期将有消息公布

    韩春雨称已能重复实验结果 近期将有消息公布

  • 英国研发“杀生”机器人 通过生命体获取能量

    英国研发“杀生”机器人 通过生命体获取能量

  • 未来两年人工智能要怎么走?看这篇就够了

    未来两年人工智能要怎么走?看这篇就够了

网友点评网友点评
阅读推荐阅读推荐

据国外媒体报道,在过去两年内,聊天机器人(chatbot)、人工智能以及机器学习的研发和采用取得了巨大进展。许多初创公司正利用人工智能和...

霍金 视觉中国 图 英国著名物理学家霍金(Stephen Hawking)再次就人工智能(AI)发声,他认为:对于人类来说,强大AI的出现可能是最美妙的...

文|郑娟娟 今年,人工智能(AI) 60岁了。在AI60岁的时候,笔者想要介绍一下AI100,一个刚刚2岁的研究项目,但它的预设寿命是100年,甚至更长...

AlphaGo与李世石的人机大战,为大众迅速普及了人工智能的概念。 但对谷歌而言,除了下围棋,现在的人工智能进展到哪一步了?未来,人工智能...