设为首页 收藏本站
查看: 1014|回复: 0

[经验分享] Oracle性能优化之oracle里表、索引、列的统计信息

[复制链接]

尚未签到

发表于 2017-12-10 21:11:33 | 显示全部楼层 |阅读模式
一、表的统计信息
  表的统计信息用于描述表的详细信息,包括记录数(num_rows)、表块的数量(blocks)、平均行长度(avg_row_len)等典型维度。这些维度可以通过数据字典表DBA_TABLESDBA_TAB_PARTITIONSDBA_TAB_SUBPARTITIONS来分别查看表、分区表的分区和分区表的子分区的统计信息。
二、索引的统计信息
  索引的统计信息描述了索引的详细信息,它包含了索引的层级(blevel)、叶子块数量(leaf_blocks)、聚簇因子(clustering_factor)等典型维度。这些维度可以通过数据字典视图DBA_INDEXES、DBA_IND_PARTITIONS和DBA_IND_SUBPARTITIONS来分别查看索引、分区索引的分区、局部分区索引的子分区的统计信息。
1、层级(level)
  层级表示从根节点到叶子块的深度,层级被CBO用于计算访问索引叶子块的成本,层级越大,表示从根节点到叶子块所需要访问的数据块的数量就越多,耗费的i/o就会越多,索引访问的成本就会越大。在数据库里如果需要降低索引的层级,需要rebuild才可以。
2、聚簇因子的含义及重要性
  oracle数据库中,聚簇因子是指按照索引键值排序的索引行和存储于对应表中的数据行的存储顺序的相似程度。oracle数据库按照如下算法计算聚簇因子:
  (1)聚簇因子初始值为1.
  (2)oracle首先定位到目标索引处于最左边的叶子块。
  (3)从最左边叶子块的第一个索引键值所在的索引行开始顺序扫描,在顺序扫描的过程中,oracle会比较当前索引行的rowid和之前那个索引行的rowid,如果这两个rowid并不是指向同一个表块,那么oracle就将聚簇因子的当前值递增1;如果这两个rowid是指向同一个表块,oracle就不改变聚簇因子的值。oracle在比对rowid时并不会回表去访问相应的表块。
  (4)上述的比对过程会持续下去,知道扫描完目标索引的所有索引块的所有索引行。
  (5)上述顺序扫描完成后,聚簇因子的当前值就是索引统计信息中的clustering_factor,oracle将其存储在数据字典里。
  由以上的过程可知:聚簇因子高的索引走索引范围扫描时比相同条件下聚簇因子低的索引要耗费更多的物理i/o,所以聚簇因子高的索引走索引范围扫描的成本会比相同条件下聚簇因子低的索引走索引范围扫描的成本高。即聚簇因子越小越好。
  oracle数据库中,能够降低聚簇因子的唯一方法就是对表中数据按照目标索引的索引键值排序后重新存储。
  oracle数据库里,cbo在计算索引范围扫描(index range scan)的成本计算公式入下:
  (*)IRS COST=I/O COST+CPU COST
  (*)I/O COST=INDEX ACCESS I/O COST+TABLE ACCESS I/O COST
  (*)index access i/o cost=blevel_celt(#leaf_blocks*ix_sel)
  (*)table access i/o cost=celt(clustering_factor*ix_sel_with_filters)
  从这个公式可以推断出走索引范围扫描的成本可以近似看作是与聚簇因子成正比。因此,聚簇因子值得大小实际对CBO判断是否走相关索引起着至关重要的作用。
3、列的统计信息
  oracle里列的统计信息用于描述oracle数据库里列的详细信息,包括列的distinct值(num_distinct)、列的null值(num_nulls)得数量、列的最小值(low_value)、列的最大值(high_value)等一些典型维度。可以通过数据字典dba_tab_col_statistics、dba_part_col_statistics和dba_subpart_col_statistics分别查看表、分区表的分区、分区表的子分区的列的统计信息。
  (1)列的distinct值(上述数据字典中字段num_distinct表示distinct值数量),cbo用num_distinct值来计算目标列做等值查询时的可选择率。
  (2)上述字典中的字段num_nulls存储的就是目标列的null值数量,cbo用num_null值来评估对目标列施加“is null”或“is not null”条件后的返回结果集cardinality。另外cbo还用num_nulls值来调整对有null值得目标列做等值查询时的可选择率selectivity。
  对目标列进行等值查询时可选择率计算公式:selectivity=(1/num_distinct)*((num_rows-num_nulls)/num_rows)
  (3)上述字典的列low_value和high_value值就是目标列的最小值和最大值,cbo通过low_value和high_value来计算目标列进行范围查询时可选择率selectivity的值。
  没有直方图,目标列范围查询可选择率计算公式(略)。
3.1直方图(histogram)
1)直方图含义
  在oracle数据库中,CBO会默认认为目标列的数据在最小值low_value和最大值high_value之间是均匀分布的,并且会根据这个均匀分布的原则来计算对目标列施加查询条件后的可选择率以及结果集的cardinality,进而据此来计算成本值并且选择执行计划。但是目标列的数据是均匀分布的这个原则并不总是准确的,在实际的系统中,我们很容易看到一些目标列的数据分布式不均匀的,甚至是极度倾斜的,分布极不均匀。对这样的列如果还按照均匀分布的原则去计算可选择率和结果集,并据此来计算成本,选择执行计划,那么CBO所选择的执行计划就可能是不合理的,甚至是错误的。
  对于上述问题,oracle引入了直方图。直方图是一种特殊的列的统计信息,它描述了目标列的数据分布情况。可以通过数据字典视图DBA_TAB_HISTOGRAMS、DBA_PART_HISTOGRAMS和DBA_SUBPART_HISTOGRAMS来分别查看表、分区表的分区和分区表的子分区的直方图统计信息。
  如果对目标列收集了直方图,则意味着CBO将不再认为该列上的数据是分布不均匀的,CBO就会用该目标列上的直方图统计信息来计算对该列施加查询条件后的可选择率和返回的结果集的cardinility,进而据此计算成本并选择相应的执行计划。即直方图就是oracle为了专门准确评估这种目标列分布不均匀的可选择率和结果集cardinility的方法。
2)直方图类型
  oracle数据库里的直方图使用了一种称为bucket的方式来描述目标列的数据分布。根据bucket的数量,直方图分为2类:
  (1)frequency类型直方图:存储在数据字典里用于描述目标列直方图的bucket数量等于目标列的distinct数量。
  oracle直方图针对于文本类型的列收集直方图统计信息,则oracle只会将该文本字段头32位字符取出来,并将其转换成一个浮点数。然后将这个浮点数作为直方图统计信息存储在数据字典里。
  (2)heigh balanced类型直方图:存储在数据字典里用于描述目标列直方图的bucket数量小于目标列的distinct数量。

运维网声明 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.iyunv.com/thread-422778-1-1.html 上篇帖子: [Oracle]关于Oracle分页写法的性能分析及ROWNUM说明 下篇帖子: DbVisualizer:Oracle触发器,解决ORA-04098: 触发器
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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