From: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> |
---|---|
To: | Mark Mielke <mark(at)mark(dot)mielke(dot)cc> |
Cc: | Conor Walsh <ctw(at)adverb(dot)ly>, jd(at)commandprompt(dot)com, Robert Haas <robertmhaas(at)gmail(dot)com>, "pgsql-performance(at)postgresql(dot)org" <pgsql-performance(at)postgresql(dot)org> |
Subject: | Re: Does auto-analyze work on dirty writes? (was: Re: [HACKERS] Slow count(*) again...) |
Date: | 2011-02-04 15:41:04 |
Message-ID: | 22836.1296834064@sss.pgh.pa.us |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-hackers pgsql-performance |
Mark Mielke <mark(at)mark(dot)mielke(dot)cc> writes:
> My understanding is:
> 1) Background daemon wakes up and checks whether a number of changes
> have happened to the database, irrelevant of transaction boundaries.
> 2) Background daemon analyzes a percentage of rows in the database for
> statistical data, irrelevant of row visibility.
> 3) Analyze is important for both visible rows and invisible rows, as
> plan execution is impacted by invisible rows. As long as they are part
> of the table, they may impact the queries performed against the table.
> 4) It doesn't matter if the invisible rows are invisible because they
> are not yet committed, or because they are not yet vacuumed.
> Would somebody in the know please confirm the above understanding for my
> own piece of mind?
No.
1. Autovacuum fires when the stats collector's insert/update/delete
counts have reached appropriate thresholds. Those counts are
accumulated from messages sent by backends at transaction commit or
rollback, so they take no account of what's been done by transactions
still in progress.
2. Only live rows are included in the stats computed by ANALYZE.
(IIRC it uses SnapshotNow to decide whether rows are live.)
Although the stats collector does track an estimate of the number of
dead rows for the benefit of autovacuum, this isn't used by planning.
Table bloat is accounted for only in terms of growth of the physical
size of the table in blocks.
regards, tom lane
From | Date | Subject | |
---|---|---|---|
Next Message | Oleg Bartunov | 2011-02-04 15:46:20 | Re: CommitFest progress - or lack thereof |
Previous Message | Heikki Linnakangas | 2011-02-04 15:32:59 | Re: SSI patch version 14 |
From | Date | Subject | |
---|---|---|---|
Next Message | Cédric Villemain | 2011-02-04 15:45:39 | Re: Talking about optimizer, my long dream |
Previous Message | Mikkel Lauritsen | 2011-02-04 15:22:02 | Different execution plans for semantically equivalent queries |