Re: Detecting if current transaction is modifying the database

Поиск
Список
Период
Сортировка
От Christian Ohler
Тема Re: Detecting if current transaction is modifying the database
Дата
Msg-id CAOsiKEK+txdZzfirYxVP575pvhXRbuNMvcshGyCLo6aC1nqSGA@mail.gmail.com
обсуждение исходный текст
Ответ на Re: Detecting if current transaction is modifying the database  (Alex Ignatov <a.ignatov@postgrespro.ru>)
Ответы Re: Detecting if current transaction is modifying the database  (Rob Sargent <robjsargent@gmail.com>)
Re: Detecting if current transaction is modifying the database  (Tom Lane <tgl@sss.pgh.pa.us>)
Список pgsql-general
Thanks, fair point.  I should have mentioned that I know about triggers but was hoping to find a less invasive mechanism (IIUC, I'd have to install a trigger on every table) – it seems to me that Postgres should just be able to tell me whether COMMIT will do anything, it obviously has to track that somehow (or some approximation of it).

Another thing I should have mentioned is that I don't consider incrementing a sequence to be a modification.


On Fri, Aug 5, 2016 at 12:35 PM, Alex Ignatov <a.ignatov@postgrespro.ru> wrote:
Hi! Make trigger function 

Alex Ignatov
Postgres Professional: http://www.postgrespro.com
Russian Postgres Company




On Fri, Aug 5, 2016 at 10:25 PM +0300, "Christian Ohler" <ohler@shift.com> wrote:

Hi,

I'm trying to find a way to have Postgres tell me if the current transaction would modify database if I committed it now.  I can live with a conservative approximation (sometimes – ideally, rarely – get a "yes" even though nothing would be modified, but never get a "no" even though there are pending modifications).  It's acceptable (probably even desirable) if a no-op write operation like "UPDATE foo SET bar = 1 WHERE bar = 1" is considered a modification.

(The use case is an audit log mechanism vaguely similar to pgMemento.)



> If a permanent ID is assigned to the transaction (which normally happens
> only if the transaction changes the state of the database), it also holds
> an exclusive lock on its permanent transaction ID until it ends.

makes me think that I can perhaps do it as follows:

SELECT count(*) FROM pg_locks WHERE pid=pg_backend_pid() AND locktype='transactionid' AND mode='ExclusiveLock' AND granted;

Is that right?  "Permanent transaction ID" refers to the XID, correct?  Are there other, better ways?  Are there ways to avoid false positives due to temp tables?

Thanks in advance,
Christian.


В списке pgsql-general по дате отправления:

Предыдущее
От: John R Pierce
Дата:
Сообщение: Re: Streaming Replica Master-Salve Config.
Следующее
От: Rob Sargent
Дата:
Сообщение: Re: Detecting if current transaction is modifying the database