Should we SetQuerySnapshot() between actions of a rule?

From: Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>
To: pgsql-hackers(at)postgreSQL(dot)org
Subject: Should we SetQuerySnapshot() between actions of a rule?
Date: 2003-05-01 15:55:45
Message-ID: 16655.1051804545@sss.pgh.pa.us
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

I just noticed that there is an inconsistency between the way that
PREPARE executes multiple queries (since PREPARE itself accepts
only one SQL statement, any such multiple queries must have been
generated by rule expansion) and the way that it is done in
pg_exec_query_string(). The latter will do a SetQuerySnapshot()
between actions of the rule, the former only does
CommandCounterIncrement().

If you're in a serializable transaction then there's no difference
in behavior. But in READ COMMITTED mode this means that later actions
in the rule may be able to see the effects of other transactions that
committed while earlier actions were running.

ISTM we had better make the behavior consistent between PREPARE and
interactive execution. But which one do we want? I could see an
argument that it'd be best for all the actions of a rule to see a
consistent snapshot of the state of other transactions; and not doing
the extra SetQuerySnapshot() calls would save some cycles.
But perhaps we had better stick to our historical behavior.
pg_exec_query_string has done a SetQuerySnapshot per query for a long
time, and I can't recall anyone ever complaining about it.

Come to think of it, SPI also does CommandCounterIncrement but not
SetQuerySnapshot between querytrees; therefore this inconsistency
also affects SPI-based operations such as PL functions.

Comments?

regards, tom lane

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Andrew Sullivan 2003-05-01 16:32:56 Re: Should we SetQuerySnapshot() between actions of a rule?
Previous Message Josh Berkus 2003-05-01 15:07:51 Re: [HACKERS] "Adding missing from clause"