- 浏览: 76315 次
- 性别:
- 来自: 苏州
最新评论
作用: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
发表评论
-
Oracle的schema、方案、模式、用户
2012-12-07 12:11 1160今天才对这几个概念 ... -
Oracle表连接操作——Merge Sort Join(合并排序连接)
2012-08-15 15:12 3362关系型数据库并不是最早出现的数据库表现形式,之前还存在层 ... -
Oracle表连接操作——Nest Loop Join(嵌套循环)
2012-08-15 15:12 7962关系型数据库并不是最 ... -
Oracle hash join
2012-08-15 15:13 1035hash join是oracle里面一个 ... -
Oracle表连接操作——Hash Join(哈希连接)下
2012-08-15 15:13 1651Hash Join是Oracle CBO时代经常出现的一 ... -
Oracle表连接操作——Hash Join(哈希连接)上
2012-08-14 14:19 13978在Oracle中,确定连接操作类型是执行计划生成的重要方 ... -
oracle 递归查询,向上和向下遍历
2012-08-14 11:10 19381--查询全部资源信息 select * from urm_cl ... -
ORACLE中Like与Instr性能大比拼(转)
2012-08-14 11:09 980http://zhaolinjnu.blog.sohu.com ... -
SQL语句优化技术分析
2012-08-14 11:08 968一、操作符优化1、IN 操 ... -
CBO和RBO介绍
2012-08-14 11:08 901Rule Based Optimizer(RBO) ... -
Install Oracle10gXE on Ubuntu Server using apt
2012-03-19 17:22 845With Oracle Database XE in prod ... -
Merge into 详细介绍
2012-03-15 15:40 952/*Merge into 详细介绍 MERGE ... -
ora-12516 tns listener could not find available handler with matching protocol
2012-03-12 15:51 8694公司数据库安装的是 Oracle10g XE(Oracle D ... -
CUUG《Oracle 监听和TNS配置》- 笔记
2012-02-24 22:07 2209监听负责多个实例 相关文件:Listener.ora和 ... -
批处理备份oracle
2012-02-24 22:07 843@echo off @title Oracle简易数据备份工具 ... -
oracle-ORA的原理
2012-02-07 14:15 10481、在一个应用环境当中,所有的服务器使用和管理同一个数据库,目 ... -
Oracle的卸载过程
2012-02-07 12:15 919修改注册表,在开始运行中执行regedit命令,进入注册表, ... -
创建表空间文件
2012-02-07 12:12 2258--1 创建表空间文件 --1.1 创建ASIT 实体表空间 ... -
SQL触发器实例讲解
2012-02-07 12:10 847SQL触发器实例1 定义: ... -
oracle 10g 默认用户名密码及解锁
2012-02-07 12:04 10021. 安装时选择的自动安装,忘了用户名和密码,导致现在试了几个 ...
相关推荐
### DBMS_STATS.GATHER_TABLE_STATS详解 #### 一、概述 `DBMS_STATS.GATHER_TABLE_STATS` 是 Oracle 数据库中的一个重要过程,主要用于收集表、列和索引的统计信息,这些统计信息对于优化器选择合适的执行计划至关...
#### 三、DBMS_STATS的关键参数详解 ##### 1. Options参数 Options参数用于控制Oracle统计信息的收集方式,主要有四种预设方法: - **GATHER**:重新分析整个架构(Schema)的所有对象。 - **GATHEREMPTY**:仅分析...
`DBMS_STATS.gather_table_stats()`和`DBMS_STATS.gather_schema_stats()`过程可用于分析单个表或整个模式,参数如`degree`(并行度)、`estimate_percent`(采样比例)和`cascade`(级联收集)可根据实际情况调整。...
#### 五、`dbms_stats`的主要参数详解 - **options参数**:控制Oracle统计的刷新方式。提供了四种预设方法: - `LGATHER`:重新分析整个架构(Schema)。 - `LGATHEREMPTY`:只分析目前还没有统计的表。 - `...
使用`DBMS_STATS.GATHER_TABLE_STATS`函数收集统计信息,并指定`DBMS_STATS.SET_TABLE_PREFS`来设置直方图参数。 2. 分析直方图效果,根据实际情况调整直方图类型和数量。 #### 九、稳定执行计划 - **固定执行...
EXECUTE dbms_stats.gather_table_stats(ownname => 'SCHEMA_NAME', tabname => 'INVENTORY_ITEM', cascade => TRUE); -- 删除直方图 EXECUTE dbms_stats.delete_histogram('SCHEMA_NAME', 'INVENTORY_ITEM', '...
- **收集统计信息**: 使用`dbms_stats.gather_table_stats`函数可以收集指定表(本例中为`SSTS_MO_MSG`)的统计信息。 - **导出/导入统计信息**: 统计信息可以通过`export_table_stats`和`import_table_stats`函数...
CALL DBMS_STATS.GATHER_TABLE_STATS('MW_APP', 'GD_YX_ZYTDSJ'); ``` 可以通过传递`GRANULARITY => 'PARTITION'`参数来按分区收集统计信息。 - 收集索引统计信息: ```sql CALL DBMS_STATS.GATHER_INDEX_...
EXEC DBMS_STATS.GATHER_TABLE_STATS('SCHEMA_NAME', 'TABLE_NAME'); ``` 其中,`SCHEMA_NAME`是模式名称,`TABLE_NAME`是要收集统计信息的表的名称。 3. **自动统计信息收集 (Automatic Statistics Gathering):...
DBMS_STATS.GATHER_TABLE_STATS('SCHEMA_NAME', 'TABLE_NAME'); END; / ``` #### 五、存储执行计划 为了确保每次执行相同的SQL语句时都使用相同的执行计划,可以使用存储执行计划(Stored Outline)。这有助于...
DBMS_STATS.GATHER_TABLE_STATS('SCHEMA_NAME', 'TABLE_NAME'); ``` **(4) 存储过程调用** - **原因**:频繁调用存储过程导致性能下降。 - **解决方案**:考虑将多个存储过程合并或使用批量处理。 **2.4 使用...
EXEC DBMS_STATS.GATHER_SCHEMA_STATS(OWNNAME => 'USER', OPTIONS => 'GATHER AUTO'); ``` #### 八、错误处理与数据验证 1. **错误处理**:查看日志文件中的错误信息,并手动修正。 2. **数据验证**:比较源端和...
- `EXECUTE DBMS_STATS.GATHER_TABLE_STATS('<schema_name>', '<table_name>');` 这些命令可以帮助数据库收集必要的统计信息,从而提高CBO的准确性。 #### 四、CBO的特殊场景 对于具有并行度的表,即使没有统计值...
- 使用DBMS_STATS包进行统计:`EXECUTE DBMS_STATS.GATHER_TABLE_STATS('scott', 'emp');` - 删除统计信息:`SQL> analyze table emp delete statistics;` #### 八、CBO特殊情况说明 - **有并行度的表**: 即使缺乏...
这可以通过DBMS_STATS包中的相关过程实现,如GATHER_TABLE_STATS和GATHER_SCHEMA_STATS,以确保统计信息的最新性和准确性。 四、审查执行计划 执行计划是优化器为SQL语句生成的执行策略,其合理性直接影响SQL语句...