From: | Robert(dot)Farrugia(at)go(dot)com(dot)mt |
---|---|
To: | tgl(at)sss(dot)pgh(dot)pa(dot)us |
Cc: | pgsql-admin(at)postgresql(dot)org |
Subject: | Re: After VACUUM, statistics become skewed |
Date: | 2003-05-22 07:57:30 |
Message-ID: | 20030522075734.C53F29234B3@developer.postgresql.org |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-admin |
Hi Tom,
I delete the rows from the pg_statistics table and rerun the same query;
Here are the results.
NOTICE: QUERY PLAN:
Aggregate (cost=218105.86..218105.88 rows=1 width=12)
-> Group (cost=218105.86..218105.87 rows=3 width=12)
-> Sort (cost=218105.86..218105.86 rows=3 width=12)
-> Index Scan using mo_200302_calling_idx on
mobileorig_200302 (cost=0.00..218105.84 rows=3 width=12)
EXPLAIN
As you can see it is still using the wrong index but the cost is less.
I am attaching the output of the pg_stats table for the table shown in the
example.
Thanks
Robert
Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>
21/05/2003 18:51
To: Robert(dot)Farrugia(at)go(dot)com(dot)mt
cc: pgsql-admin(at)postgresql(dot)org
Subject: Re: [ADMIN] After VACUUM, statistics become skewed
Robert(dot)Farrugia(at)go(dot)com(dot)mt writes:
> Given a table around 4GB in size containing millions of records, before
> vacuuming the following query used the correct index
> (mo_200302_called_idx) which is built on answertime and
callednumber_type.
Could we see EXPLAIN ANALYZE results for both the good plan and the bad
plan, for the same query? You're not giving us comparable results.
It would also be useful to show the pg_stats entries for the table.
I suspect that the planner is being fooled by some odd statistics of
your data, but we have not got any info here with which to speculate.
> Usually by dropping the table and reloading it from
> disk may solve the problem (it may take more than one try), but this is
> becoming unpractical due to the amount of data to restore each time.
You can get back to the un-analyzed state by deleting the rows in
pg_statistic for this table, viz
delete from pg_statistic where starelid = (select oid
from
pg_class where relname =
'mobileorig_200302');
Grotty, but it sure beats dropping and reloading a big table.
regards, tom lane
Attachment | Content-Type | Size |
---|---|---|
stats.txt | text/plain | 17.5 KB |
From | Date | Subject | |
---|---|---|---|
Next Message | Gary Stainburn | 2003-05-22 08:32:39 | Re: Unsubscribe |
Previous Message | A.Bhuvaneswaran | 2003-05-22 07:08:34 | Re: SECURITY |