Oracle 收集统计值 收集统计信息

php中文网
发布: 2016-06-07 16:46:55
原创
1810人浏览过

--收集Oracle统计信息BEGIN DBMS_STATS.GATHER_TABLE_STATS(OWNNAME =gt;

--收集oracle统计信息
begin
  dbms_stats.gather_table_stats(ownname          => 'owner_name',  --数据库用户名
                                tabname          => 'table_name',  --表名
                                partname        => 'partition_name',  --分区名
                                estimate_percent => dbms_stats.auto_sample_size,
                                method_opt      => 'for all columns size repeat',
                                degree          => dbms_stats.auto_degree,
                                cascade          => true);
end;

--查询表的统计信息
SELECT *
  FROM DBA_TAB_STATISTICS S
 WHERE S.OWNER = 'OWNER_NAME'  --数据库用户名
  AND S.TABLE_NAME = 'TABLE_NAME'  --表名
 ORDER BY S.LAST_ANALYZED DESC;


--Oracle统计信息
DBMS_STATS.gather_table_stats
    (ownname varchar2,
    tabname varchar2,
    partname varchar2 default null,
    estimate_percent number default  to_estimate_percent_type(get_param('ESTIMATE_PERCENT')),
    block_sample boolean default FALSE,
    method_opt varchar2 default get_param('METHOD_OPT'),
    degree number default to_degree_type(get_param('DEGREE')),
    granularity varchar2 default get_param('GRANULARITY'),
    cascade boolean default to_cascade_type(get_param('CASCADE')),
    stattab varchar2 default null, statid varchar2 default null,
    statown varchar2 default null,
    no_invalidate boolean default to_no_invalidate_type(get_param('NO_INVALIDATE')),
    stattype varchar2 default 'DATA',
    force boolean default FALSE);

/*
参数说明:
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 SIZE | REPEAT | AUTO | SKEWONLY:
                                              统计指定列的histograms.N的取值范围[1,254]; R
                                              EPEAT上次统计过的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.
cascade:      是收集索引的信息.默认为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:        即使表锁住了也收集统计信息

I-Shop购物系统
I-Shop购物系统

部分功能简介:商品收藏夹功能热门商品最新商品分级价格功能自选风格打印结算页面内部短信箱商品评论增加上一商品,下一商品功能增强商家提示功能友情链接用户在线统计用户来访统计用户来访信息用户积分功能广告设置用户组分类邮件系统后台实现更新用户数据系统图片设置模板管理CSS风格管理申诉内容过滤功能用户注册过滤特征字符IP库管理及来访限制及管理压缩,恢复,备份数据库功能上传文件管理商品类别管理商品添加/修改/

I-Shop购物系统 0
查看详情 I-Shop购物系统

*/
--例子:
execute dbms_stats.gather_table_stats(ownname => 'owner',
                                      tabname => 'table_name' ,
                                      estimate_percent => null ,
                                      method_opt => 'for all indexed columns' ,
                                      cascade => true);
--GATHER_INDEX_STATS
--==========================
BEGIN
SYS.DBMS_STATS.GATHER_INDEX_STATS (OwnName => 'ABC',
                                  IndName => 'IDX_FUNC_ABC',
                                  Estimate_Percent => 10,
                                  Degree => SYS.DBMS_STATS.DEFAULT_DEGREE,
                                  No_Invalidate => FALSE);
END;

linux

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号