Re: why do we need two snapshots per query? - Mailing list pgsql-hackers

From Florian Pflug
Subject Re: why do we need two snapshots per query?
Date
Msg-id A70E3B1B-73A5-476B-AE21-42099772B965@phlo.org
Whole thread Raw
In response to Re: why do we need two snapshots per query?  (Robert Haas <robertmhaas@gmail.com>)
Responses Re: why do we need two snapshots per query?
List pgsql-hackers
On Nov11, 2011, at 16:18 , Robert Haas wrote:
> In the extend query protocol scenario, it seems to me that keeping the
> snapshot would be both wrong and a bad idea.  It would be wrong
> because the user will (I think) expect the query can see all rows that
> were marked as committed prior to Execute message.  It would be a bad
> idea because we'd have to keep that snapshot advertised for the entire
> time between Parse and Execute, even if the client was sitting there
> doing nothing for a long time, which would hold back RecentGlobalXmin.

Hm, but that'd penalize clients who use the extended query protocol, which
they have to if they want to transmit out-of-line parameters. You could
work around that by making the extended protocol scenario work like the
simply protocol scenario if the unnamed statement and/or portal is used.

Since clients presumably use pipelined Parse,Bind,Execute messages when
using the unnamed statement and portal, they're unlikely to observe the
difference between a snapshot taken during Parse, Bind or Execute.

best regards,
Florian Pflug



pgsql-hackers by date:

Previous
From: Tom Lane
Date:
Subject: Re: Manual anti-wraparound vacuums
Next
From: Tom Lane
Date:
Subject: Re: why do we need two snapshots per query?