`
zhaowei_520
  • 浏览: 123374 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

DBMS_STATS.GATHER_TABLE_STATS详解

阅读更多
转载:http://space.itpub.net/7419833/viewspace-422844

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);
分享到:
评论

相关推荐

    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