analyze vs dbms_stats [message #256339] |
Fri, 03 August 2007 19:44 data:image/s3,"s3://crabby-images/3bcce/3bcce7084f96de28f8958fb8ba64988a13b0e75a" alt="Go to next message Go to next message" |
alantany
Messages: 115 Registered: July 2007
|
Senior Member |
|
|
Hello,all!
I have a new question on analyze and dbms_stats.
I did a test below:
SQL> create table tab1(a number(1));
Table created
SQL> create table tab2(a char(1));
Table created
SQL> insert into tab1 values(1);
1 row inserted
SQL> insert into tab2 values('1');
1 row inserted
SQL> commit;
Commit complete
SQL> analyze table tab1 compute statistics;
Table analyzed
SQL> analyze table tab2 compute statistics;
Table analyzed
SQL> select table_name,AVG_ROW_LEN from user_tables where table_name in ('TAB1','TAB2');
TABLE_NAME AVG_ROW_LEN
------------------------------ -----------
TAB1 6
TAB2 5
SQL> exec dbms_stats.gather_table_stats(user,'TAB1')
PL/SQL procedure successfully completed
SQL> exec dbms_stats.gather_table_stats(user,'TAB2')
PL/SQL procedure successfully completed
SQL> select table_name,AVG_ROW_LEN from user_tables where table_name in ('TAB1','TAB2');
TABLE_NAME AVG_ROW_LEN
------------------------------ -----------
TAB1 3
TAB2 2
I have 2 questions:
1:Why the results of ANALYZE and DBMS_STATS are different?
2:I think lenth of columns of tab1 and tab2 is 1 bytes,but the result is 2,3(using DBMS_STATS) and
5,6(using ANALYZE),why?
I would be very thankful if ¿you give me some explain!
Best Regards!
Alan
|
|
|
|
Re: analyze vs dbms_stats [message #256368 is a reply to message #256339] |
Sat, 04 August 2007 01:20 data:image/s3,"s3://crabby-images/5d024/5d02489f93cb86dd1a658de391c37413cb5e3f44" alt="Go to previous message Go to previous message" |
data:image/s3,"s3://crabby-images/7dccb/7dccb0215d12eec7aff82634bff49c1f5d959d76" alt="" |
Michel Cadot
Messages: 68737 Registered: March 2007 Location: Saint-Maur, France, https...
|
Senior Member Account Moderator |
|
|
One includes row/column header the other one no. The difference is small in real cases.
As Mohammad said, no more use analyze to compute optimizer statistics use dbms_stats.
Regards
Michel
|
|
|