ANALYZE
描述
该语句用于收集表或表分区的统计信息。
语法
ANALYZE TABLE table_name UPDATE HISTOGRAM ON column_name_list WITH INT_NUM BUCKETS;
当配置项 enable_sql_extension 为 TRUE 的时候,可以使用如下语法:
ANALYZE TABLE table_name [use_partition] COMPUTE STATISTICS [ for_clause ];
use_partition:
PARTITION (parition_name [,partition_name,....])
| SUBPARTITION(subpartition_name, [,subpartition_name,...])
analyze_statistics_clause:
COMPUTE STATISTICS [analyze_for_clause]
| ESTIMATE STATISTICS [analyze_for_clause] [SAMPLE INTNUM {ROWS | PERCENTAGE}]
analyze_for_clause:
FOR TABLE
| FOR ALL [INDEXED | HIDDEN] COLUMNS [size_clause]
| FOR COLUMNS [size clause] column [size_clause] [,column [size_clause]...]
size_clause:
SIZE integer
| SIZE REPEAT
| SIZE AUTO
| SIZE SKEWONLY
column:
column_name
| (column_name [, column_name])
参数解释
| 参数 | 描述 |
|---|---|
| table_name | 指定要分析的表。 |
| INT_NUM | 整数,即 Buckets 的个数。有关 Buckets 的取值,请参见 method_opt。 |
| use_partition | 指定分区名,如果指定为表名,则不收集分区统计信息。 |
| compute_statistics_clause | 指定 COMPUTE STATISTICS 可以计算分析对象的精确统计信息,并将其存储在数据字典中。分析表时,会同时统计表和列的统计信息。 |
| for_clause | 指定要分析整个表,或者只分析特定的列。
|
| estimate_statistics_clause | 指定 ESTIMATE STATISTICS 可以估计分析对象的统计信息,并将其存储在数据字典中。 |
| SAMPLE | 指定用于估计统计信息使用的分析对象中的采样数据量。如果省略该参数,则会根据数据库优化器自动选择一个合适的比例进行采样。
|
示例
- 收集
test表的统计信息,列的桶个数为 30 个。
CREATE TABLE test (c1 NUMBER(30) PRIMARY KEY,c2 VARCHAR(50));
Query OK, 0 rows affected (0.001 sec)
ANALYZE TABLE test UPDATE HISTOGRAM ON c1,c2 with 30 buckets;
Query OK, 0 rows affected (0.001 sec)
- 当配置项
enable_sql_extension为TRUE的时候,使用以下语法收集用户user01的表test的统计信息,所有列的桶个数设定为 128。
ALTER SYSTEM SET enable_sql_extension = TRUE;
Query OK, 0 rows affected (0.001 sec)
ANALYZE TABLE test COMPUTE STATISTICS FOR ALL COLUMNS SIZE 128;
Query OK, 0 rows affected (0.001 sec)