前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【Oracle】-【创建索引】-创建索引的操作原理与一些体会

【Oracle】-【创建索引】-创建索引的操作原理与一些体会

作者头像
bisal
发布2019-01-29 10:21:15
5140
发布2019-01-29 10:21:15
举报

1、将index key的data读到cache。如果之前这部分数据未读到DB Cache,那么此时可能有db file scatter read write的等待事件。

2、对index key的data进行排序。排序的操作,如果sort_area_size或pga_aggregate_target不大的情况下,可能就会做disk sort,我们知道,磁盘排序的效率要小于Cache不少,因此速度上肯定受影响,会有direct path read/write,同时也会消耗CPU time。

3、创建新的index segment(补充:block是最小的I/O单元,extent是最小的Oracle空间分配单元,segment又是由extent组成的,Oracle中表、索引、视图等等的存储都可以看做是segement),将排序的index data写到创建的index segment中。那么如果index很大,就会有许多的redo log相关等待,例如log file sync,log buffer space,log file parallel write等。

参考牛人的随笔后,

关于创建索引的一点体会:

(1)、关于利用并行度创建索引,前提是多个CPU,单CPU下用并行度创建索引,可能会造成资源的争用,dave曾经推测过可能是CPU的争用,也可能是I/O的争用,造成的结果就是比不用并行度消耗更多的时间才能创建索引。

(2)、在建大表的索引时,可以增大PGA,增大temp tablespace,因为排序通常是在PGA中进行的,防止因空间或内存不足导致需要disk排序,是最大的问题。但往往有时这些参数不让随意调整。那么nologging这种方式可能还是可以做的。

关于索引利用的一点体会:

(1)、关于第二点,index data都会进行排序,那么利用索引的这个特性,有时可以避免对表的排序操作,例如当需要查询max或min这种排序结果时,只要建立某个字段的索引,就可以避免order by的使用,因为index中的数据已经排序。

(2)、同时利用索引,有时也可以避免回表,对于select某些索引字段时,这种方式的效果更好。

关于这些方面这里谈的很少,后面找个机会单独讨论。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2013年08月09日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档