网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.详细讲解"Oracle"服务器的常用命.
.如何将Oralce数据库中孤独临时段.
.调整缓冲区高速缓存(Buffer Cach.
.ORACLE数据库不用索引来查找数据.
.怎样在Oracle 10g存储过程中log错.
.如何让数据库使用spfile启动.
.rman备份方式半功略.
.Oracle中如何用T-SQL语句建立跟踪.
.在Oracle中获取磁盘空间的使用情.
.实战经验Oracle数据库基本操作步.
.理解 Linux 配置文件.
.24×7环境转移数据库服务器.
.用.NET新提供的managed provider.
.Oracle初学点滴-(2).
.Linux着作权须知.
.Linux ADSL Multipath Routing S.
.Oracle 10g列掩码与关系视图比较.
.Oracle身份管理在企业中的应用.
.自动备份Oracle数据库.
.Oracle9i 数据库管理实务讲座(六.

关于dbms_stats取代analyze

发表日期:2008-2-9


  自从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 ,可能导致误差。 drop table T3; CREATE TABLE T3(i number, p number,sp number)PARTITION BY RANGE(p)
SUBPARTITION BY HASH(sp) SUBPARTITIONS 2 (PARTITION q1 VALUES LESS THAN(3) TABLESPACE USERS,
PARTITION q2 VALUES LESS THAN(MAXVALUE) TABLESPACE USERS); declare
i number;
begin
for i in 1..100000 loop
insert into T3 values(i,mod(i,7), mod(i,8));
if( mod(i, 10000) = 0) then commit; end if;
end loop;
for i in 1..50000 loop
insert into T3 values(i,mod(i,7), mod(i,8)+5);
if( mod(i, 10000) = 0) then commit; end if;
end loop;
end; / 如上建立一个分区表 SQL> exec DBMS_STATS.GATHER_TABLE_STATS('ORACLE','T3',granularity => 'ALL'); PL/SQL procedure sUCcessfully completed. SQL> select GLOBAL_STATS from dba_tables where table_name='T3'; GLO
---
YES 计算了Global Statistics SQL> select COLUMN_NAME,NUM_DISTINCT,DENSITY,SAMPLE_SIZE,AVG_COL_LEN from user_TAB_COL_STATISTICS where table_name='T3'; COLUMN_NAME NUM_DISTINCT DENSITY SAMPLE_SIZE AVG_COL_LEN
------------------------------ ------------ ---------- ----------- -----------
I 100000 .00001 150000 5
P 7 .142857143 150000 3
SP 13 .076923077 150000 3
SQL> analyze table t3 delete statistics; Table analyzed. SQL> select GLOBAL_STATS from dba_tables where table_name='T3'; GLO
---
YES 看来analyze不能删除dbms_stats的统计信息? SQL> analyze table t3 compute statistics; Table analyzed. SQL> select COLUMN_NAME,NUM_DISTINCT,DENSITY,SAMPLE_SIZE,AVG_COL_LEN from user_TAB_COL_STATISTICS where table_name='T3'; COLUMN_NAME NUM_DISTINCT DENSITY SAMPLE_SIZE AVG_COL_LEN
------------------------------ ------------ ---------- ----------- -----------
I 100000 .00001 150000 5
P 7 .142857143 150000 3
SP 13 .076923077 150000 3   没有变,还是一样。 Confused ? SQL> select GLOBAL_STATS from dba_tables where table_name='T3'; GLO
---
YES
SQL> exec dbms_stats.DELETE_TABLE_STATS('oracle','t3'); PL/SQL procedure successfully completed. SQL> select GLOBAL_STATS from dba_tables where table_name='T3';
GLO
---
NO 《 ----- 有效果了
SQL> analyze table t3 compute statistics; Table analyzed. SQL> select COLUMN_NAME,NUM_DISTINCT,DENSITY,SAMPLE_SIZE,AVG_COL_LEN from user_TAB_COL_STATISTICS where table_name='T3'; COLUMN_NAME NUM_DISTINCT DENSITY SAMPLE_SIZE AVG_COL_LEN
------------------------------ ------------ ---------- ----------- -----------
I 150000 6.6667E-06 4
P 7 .142857143 2
SP 8 .125 2 SQL> select GLOBAL_STATS from dba_tables where table_name='T3'; GLO
---
NO   可见,sometimes,analyze出错了。当CBO只需要partition的统计信息的时候还好,当使用表上的全局统计信息的时候,有可能产生不正确的执行计划。
上一篇:数据库恢复实例 人气:751
下一篇:Index Range Scan 人气:906
浏览全部Oracle教程的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐