Oracle动态采样详解.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Oracle动态采样详解   动态采样概述   动态采样(Dynamic Sampling)技术的最初提出是在Oracle 9i R2,在段(表,索引,分区)没有分析的情况下,为了使CBO 优化器得到足够的信息以保证做出正确的执行计划而发明的一种技术,可以把它看做分析手段的一种补充。   当段对象没有统计信息时(即没有做分析),动态采样技术可以通过直接从需要分析的对象上收集数据块(采样)来获得CBO需要的统计信息。   一个简单的例子: 创建表: SQL??create table t as select??owner,object_type from dba_objects; Table created.? 查看表的记录数: SQL select count(*) from t ??COUNT(*) ---------- ?????50419???-- 记录数 这里创建了一张普通表,没有做分析,我们在hint中用0级来限制动态采样,此时CBO唯一可以使用的信息就是表存储在数据字典中的一些信息,如有多少个extent,有多少个block,但是这些信息是不够的。 SQL set autotrace trace exp SQL select * from t; Execution Plan ---------------------------------------------------------- Plan hash value: 1601196873 -------------------------------------------------------------------------- | Id??| Operation?????????| Name | Rows??| Bytes | Cost (%CPU)| Time?????| -------------------------------------------------------------------------- |???0 | SELECT STATEMENT??|??????| 12007 |???328K|????34???(0)| 00:00:01 | |???1 |??TABLE ACCESS FULL| T????| 12007 |???328K|????34???(0)| 00:00:01 | --------------------------------------------------------------------------? 在没有做动态分析的情况下?,CBO估计的记录数是?12007条,与真实的?50419相差甚远。? 动态分析来后:? SQL select * from t; Execution Plan ---------------------------------------------------------- Plan hash value: 1601196873 -------------------------------------------------------------------------- | Id??| Operation?????????| Name | Rows??| Bytes | Cost (%CPU)| Time?????| -------------------------------------------------------------------------- |???0 | SELECT STATEMENT??|??????| 45596 |??1246K|????35???(3)| 00:00:01 | |???1 |??TABLE ACCESS FULL| T????| 45596 |??1246K|????35???(3)| 00:00:01 | -------------------------------------------------------------------------- Note ----- ???- dynamic sampling used for this statement? 在Oracle 10g中默认对没有分析的段做动态采样,上面的查询结果显示使用了动态采样,CBO计的结果是?45596与?50419很接近了。?由于动态采样只是对有限的一些数据块做分析,来对整个表做出估算,所以无法和实际值完全吻合也是很正常的。 注意:在没有动态采样的情况下,对于没有分析过的段,CBO也可能错误地将结果判断的程度扩大话?。? 见下列 SQL delete from t; 50419 rows deleted. SQL set

文档评论(0)

1234554321 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档