Re: txid_current() forces a real xid - Mailing list pgsql-hackers

From Marko Kreen
Subject Re: txid_current() forces a real xid
Date
Msg-id CACMqXC+HLVyv9exqC=3j_aMx8X0tZG0gAMMHQHRkq=ExCJY1eg@mail.gmail.com
Whole thread Raw
In response to txid_current() forces a real xid  (Bruce Momjian <bruce@momjian.us>)
Responses Re: txid_current() forces a real xid
List pgsql-hackers
On Mon, Jul 11, 2011 at 5:59 PM, Bruce Momjian <bruce@momjian.us> wrote:
> Right now, calling txid_current() causes a session to create a
> non-virtual xid if not already assigned, so observing the xid creates
> it, which seems kind of odd.  Is that intended?  Here is the C code:

Yes, it was intentional, the value will be written out.

It could be even called before actual writing statement is run
so returning anything that will become invalid later during
transaction is dangerous.

If you have use-case that requires frequent calling of that function
in read-only transaction, and prefer to see virtual txids
I suggest implementing it as new function.

--
marko


pgsql-hackers by date:

Previous
From: Kohei KaiGai
Date:
Subject: Re: [v9.1] sepgsql - userspace access vector cache
Next
From: Bruce Momjian
Date:
Subject: TODO list updated