`
lizhen3708693
  • 浏览: 76171 次
  • 性别: Icon_minigender_1
  • 来自: 苏州
社区版块
存档分类
最新评论

DBMS_STATS.GATHER_TABLE_STATS详解

阅读更多

 

作用:DBMS_STATS.GATHER_TABLE_STATS统计表,列,索引的统计信息.

DBMS_STATS.GATHER_TABLE_STATS的语法如下:

DBMS_STATS.GATHER_TABLE_STATS (   ownname          VARCHAR2,     tabname          VARCHAR2,     partname         VARCHAR2,   estimate_percent NUMBER,     block_sample     BOOLEAN,   method_opt       VARCHAR2,   degree           NUMBER,   granularity      VARCHAR2,     cascade          BOOLEAN,   stattab          VARCHAR2,     statid           VARCHAR2,   statown          VARCHAR2,   no_invalidate    BOOLEAN,   force            BOOLEAN);

参数说明:

ownname:要分析表的拥有者

tabname:要分析的表名.

partname:分区的名字,只对分区表或分区索引有用.

estimate_percent:采样行的百分比,取值范围[0.000001,100],null为全部分析,不采样. 常量:DBMS_STATS.AUTO_SAMPLE_SIZE是默认值,由oracle决定最佳取采样值.

block_sapmple:是否用块采样代替行采样.

method_opt:决定histograms信息是怎样被统计的.method_opt的取值如下:

for all columns:统计所有列的histograms.

for all indexed columns:统计所有indexed列的histograms.

for all hidden columns:统计你看不到列的histograms

for columns <list> SIZE <N> | REPEAT | AUTO | SKEWONLY:统计指定列的histograms.N的取值范围[1,254]; REPEAT上次统计过的histograms;AUTO由oracle决定N的大小;SKEWONLY multiple end-points with the same value which is what we define by "there is skew in the data

degree:决定并行度.默认值为null.

granularity:Granularity of statistics to collect ,only pertinent if the table is partitioned.

cascace:是收集索引的信息.默认为falase.

stattab指定要存储统计信息的表,statid如果多个表的统计信息存储在同一个stattab中用于进行区分.statown存储统计信息表的拥有者.以上三个参数若不指定,统计信息会直接更新到数据字典.

no_invalidate: Does not invalidate the dependent cursors if set to TRUE. The procedure invalidates the dependent cursors immediately if set to FALSE.

force:即使表锁住了也收集统计信息.

例子:

execute dbms_stats.gather_table_stats(ownname => 'owner',tabname => 'table_name' ,estimate_percent => null ,method_opt => 'for all indexed columns' ,cascade => true);

------------------------------------------------------------------------------------------------------------------------

自从Oracle8.1.5引入dbms_stats包,Experts们便推荐使用dbms_stats取代analyze。 理由如下

dbms_stats可以并行分析
dbms_stats有自动分析的功能(alter table monitor )
analyze 分析统计信息的不准确some times


1,2好理解,且第2点实际上在VLDB中是最吸引人的;3以前比较模糊,看了metalink236935.1 解释,analyze在分析Partition表的时候,有时候会计算出不准确的Global statistics .

原因是,dbms_stats会实在的去分析表全局统计信息(当指定参数);而analyze是将表分区(局部)的statistics 汇总计算成表全局statistics ,可能导致误差。

如果想分析整个用户或数据库,还可以采用工具包,可以并行分析
Dbms_utility(8i以前的工具包)
Dbms_stats(8i以后提供的工具包)

dbms_stats.gather_schema_stats(User,estimate_percent=>100,cascade=> TRUE);
dbms_stats.gather_table_stats(User,TableName,degree => 4,cascade => true);

这是对命令与工具包的一些总结

1、对于分区表,建议使用DBMS_STATS,而不是使用Analyze语句。
a) 可以并行进行,对多个用户,多个Table
b) 可以得到整个分区表的数据和单个分区的数据。
c) 可以在不同级别上Compute Statistics:单个分区,子分区,全表,所有分区
d) 可以倒出统计信息
e) 可以用户自动收集统计信息

2、DBMS_STATS的缺点
a) 不能Validate Structure
b) 不能收集CHAINED ROWS, 不能收集CLUSTER TABLE的信息,这两个仍旧需要使用Analyze语句。
c) DBMS_STATS 默认不对索引进行Analyze,因为默认Cascade是False,需要手工指定为True

3、对于oracle 9里面的External Table,Analyze不能使用,只能使用DBMS_STATS来收集信息。

-----------------------------------------------------------------
10G的文档是这么说的:
Do not use the COMPUTE and ESTIMATE clauses of ANALYZE to collect optimizer statistics. These clauses are supported for backward compatibility. Instead, use the DBMS_STATS package, which lets you collect statistics in parallel, collect global statistics for partitioned objects, and fine tune your statistics collection in other ways. The cost-based optimizer, which depends upon statistics, will eventually use only statistics that have been collected by DBMS_STATS

analyze的功能已经明确:
Use the ANALYZE statement (rather than DBMS_STATS) for statistics collection not related to the cost-based optimizer :

To use the VALIDATE or LIST CHAINED ROWS clauses

To collect information on freelist blocks

 

 

http://kedron.blogbus.com/logs/41174252.html

分享到:
评论

相关推荐

    DBMS_STATS.GATHER_TABLE_STATS详解.pdf

    ### DBMS_STATS.GATHER_TABLE_STATS详解 #### 一、概述 `DBMS_STATS.GATHER_TABLE_STATS` 是 Oracle 数据库中的一个重要过程,主要用于收集表、列和索引的统计信息,这些统计信息对于优化器选择合适的执行计划至关...

    dbms_stats.docx

    #### 三、DBMS_STATS的关键参数详解 ##### 1. Options参数 Options参数用于控制Oracle统计信息的收集方式,主要有四种预设方法: - **GATHER**:重新分析整个架构(Schema)的所有对象。 - **GATHEREMPTY**:仅分析...

    oracle10G数据库性能监控与优化详解

    `DBMS_STATS.gather_table_stats()`和`DBMS_STATS.gather_schema_stats()`过程可用于分析单个表或整个模式,参数如`degree`(并行度)、`estimate_percent`(采样比例)和`cascade`(级联收集)可根据实际情况调整。...

    ORACLE 数据库的统计数据及优化

    #### 五、`dbms_stats`的主要参数详解 - **options参数**:控制Oracle统计的刷新方式。提供了四种预设方法: - `LGATHER`:重新分析整个架构(Schema)。 - `LGATHEREMPTY`:只分析目前还没有统计的表。 - `...

    SQL优化公开课1

    使用`DBMS_STATS.GATHER_TABLE_STATS`函数收集统计信息,并指定`DBMS_STATS.SET_TABLE_PREFS`来设置直方图参数。 2. 分析直方图效果,根据实际情况调整直方图类型和数量。 #### 九、稳定执行计划 - **固定执行...

    oracle的sql脚本优化实例

    EXECUTE dbms_stats.gather_table_stats(ownname =&gt; 'SCHEMA_NAME', tabname =&gt; 'INVENTORY_ITEM', cascade =&gt; TRUE); -- 删除直方图 EXECUTE dbms_stats.delete_histogram('SCHEMA_NAME', 'INVENTORY_ITEM', '...

    oracle面试经典十日记录

    - **收集统计信息**: 使用`dbms_stats.gather_table_stats`函数可以收集指定表(本例中为`SSTS_MO_MSG`)的统计信息。 - **导出/导入统计信息**: 统计信息可以通过`export_table_stats`和`import_table_stats`函数...

    oracle索引使用样例

    CALL DBMS_STATS.GATHER_TABLE_STATS('MW_APP', 'GD_YX_ZYTDSJ'); ``` 可以通过传递`GRANULARITY =&gt; 'PARTITION'`参数来按分区收集统计信息。 - 收集索引统计信息: ```sql CALL DBMS_STATS.GATHER_INDEX_...

    Oracle Statistic 统计信息

    EXEC DBMS_STATS.GATHER_TABLE_STATS('SCHEMA_NAME', 'TABLE_NAME'); ``` 其中,`SCHEMA_NAME`是模式名称,`TABLE_NAME`是要收集统计信息的表的名称。 3. **自动统计信息收集 (Automatic Statistics Gathering):...

    oracle执行计划

    DBMS_STATS.GATHER_TABLE_STATS('SCHEMA_NAME', 'TABLE_NAME'); END; / ``` #### 五、存储执行计划 为了确保每次执行相同的SQL语句时都使用相同的执行计划,可以使用存储执行计划(Stored Outline)。这有助于...

    oracle安装

    DBMS_STATS.GATHER_TABLE_STATS('SCHEMA_NAME', 'TABLE_NAME'); ``` **(4) 存储过程调用** - **原因**:频繁调用存储过程导致性能下降。 - **解决方案**:考虑将多个存储过程合并或使用批量处理。 **2.4 使用...

    oracle数据导入导出

    EXEC DBMS_STATS.GATHER_SCHEMA_STATS(OWNNAME =&gt; 'USER', OPTIONS =&gt; 'GATHER AUTO'); ``` #### 八、错误处理与数据验证 1. **错误处理**:查看日志文件中的错误信息,并手动修正。 2. **数据验证**:比较源端和...

    高级SQL优化教程.pdf

    - `EXECUTE DBMS_STATS.GATHER_TABLE_STATS('&lt;schema_name&gt;', '&lt;table_name&gt;');` 这些命令可以帮助数据库收集必要的统计信息,从而提高CBO的准确性。 #### 四、CBO的特殊场景 对于具有并行度的表,即使没有统计值...

    高级SQL优化教程(很不错的学习资料)

    - 使用DBMS_STATS包进行统计:`EXECUTE DBMS_STATS.GATHER_TABLE_STATS('scott', 'emp');` - 删除统计信息:`SQL&gt; analyze table emp delete statistics;` #### 八、CBO特殊情况说明 - **有并行度的表**: 即使缺乏...

    Oracle SQL Tuning.pdf

    这可以通过DBMS_STATS包中的相关过程实现,如GATHER_TABLE_STATS和GATHER_SCHEMA_STATS,以确保统计信息的最新性和准确性。 四、审查执行计划 执行计划是优化器为SQL语句生成的执行策略,其合理性直接影响SQL语句...

Global site tag (gtag.js) - Google Analytics