Oracle的直方图的作用就是能够让优化器选择正确的执行计划,算出执行计划中的rows来。但是并不是经常收集直方图就是好事,收集直方图是一个比较耗时的过程,如果没有必要就不要收集直方图。数据在时刻的变化所以永远得不到准确的数据。
收集直方图的时候有两点需要注意:
1.不能对基数高得列收集统计信息,因为基数高的列选择性好返回的数据就少不需要进行收集。
2.不对select 后面的列进行收集对where列后边的列进行收集,因为where后面的列式查询条件。
点击(此处)折叠或打开
- //收集统计信息收集直方图信息
- BEGIN
- DBMS_STATS.GATHER_TABLE_STATS(ownname => 'SCOTT',
- tabname =>'TEST',
- estimate_percent => 100,
- method_opt =>'for all columns size skewonly',
- no_invalidate => FALSE,
- degree =>8,
- cascade => TRUE);
- END;
- /
收集直方图的时候有两点需要注意:
1.不能对基数高得列收集统计信息,因为基数高的列选择性好返回的数据就少不需要进行收集。
2.不对select 后面的列进行收集对where列后边的列进行收集,因为where后面的列式查询条件。
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/26700739/viewspace-1308475/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/26700739/viewspace-1308475/