共计 561 个字符,预计需要花费 2 分钟才能阅读完成。
在 Oracle 数据库中,CBO 会默认目标列的数据在其最小值 low_value 和最大值 high_value 之间均匀分布,并按照均匀分布原则,来计算目标列施加查询条件后的可选择率以及结果集的 cardinality。
如果对目标收集了直方图,则意味着 CBO 不再认为目标列上的数据是均匀分布的。CBO 会用该列上的直方图的统计信息计算返回结果集的 cardinality。
验证直方图对执行计划的影响步骤:
1、创建一张表 T1
2、往表中插入倾斜度很高的数据
3、在 B 字段上创建索引
4、删除表中直方图信息
5、查看直方图信息
HISTOGRAM:NONE 代表没有直方图信息
6、查询 b = 2 的执行计划
从执行计划可以看出:查询走的是全表扫描,因为表 T1 中的数据被视为了均匀分布,CBO 认为走全表比走索引会更快
7、收集直方图信息
8、查询直方图信息
HISTOGRAM:FREQUENCY 频率直方图
可以看出此时表中已经有直方图信息
9、再次查看 b = 2 的执行计划
这个时候可以看出,执行计划走了索引,结果正确!
更多 Oracle 相关信息见 Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12
本文永久更新链接地址 :http://www.linuxidc.com/Linux/2017-09/146934.htm
正文完
星哥玩云-微信公众号