Re: Event trigger information accessibility on plpgsql - Mailing list pgsql-general

From Andrew Tipton
Subject Re: Event trigger information accessibility on plpgsql
Date
Msg-id CA+M2pVVHQ1jmi47hBhxJoE++=-7Bs=JVafMuW=ZU2utNM=V4Gg@mail.gmail.com
Whole thread Raw
In response to Event trigger information accessibility on plpgsql  (Javier de la Torre <jatorre@vizzuality.com>)
Responses Re: Event trigger information accessibility on plpgsql  (Javier de la Torre <jatorre@vizzuality.com>)
List pgsql-general
On Mon, Jul 29, 2013 at 9:12 PM, Javier de la Torre <jatorre@vizzuality.com> wrote:
Hi, 

I was looking at the new event triggers on 9.3 and was doing some testing. I have compiled PostgreSQL 9.3 Beta2
It looks from the examples that the only info right now available on plpgsql when the triggers fire is tg_event and tg_tag.

When developing on C you get access to more things. But would it be possible to do a plpgsql trigger where I have access to the table name and OID when I do an ALTER table to rename a column? Right now it feels i can only know that a table has been altered, but not which one

I recall that the event triggers functionality was quite large, and hence was split across a series of patches.  Only some of those patches were able to be committed in time for 9.3, hence the lack of information accessible from plpgsql functions.  [The crux of the issue preventing the remaining patches from landing was, I believe, disagreement over how to expose the additional information in a consistent manner.]

Here is a crazy idea that might work:  create an event trigger which is fired on any CREATE or ALTER TABLE command (for any table), and in the trigger function compare the current state of the catalog (pg_class and pg_attribute) with a "snapshot" of the previous catalog state.  If anything has changed, perform the appropriate actions and update the "snapshot" with the new state.

The downside is that this might be quite slow.  But how often do you plan to be creating and altering tables?  The full scans of the catalog tables will only happen when CREATE TABLE or ALTER TABLE commands are executed, which might be acceptable.  And when additional event trigger information is presumably added in 9.4, you can simply treat it as a performance optimization.

[I'm toying with the idea of an extension which (ab)uses event triggers in precisely this manner.  The goal is to provide built-in version control that doesn't need any external tools to be run after changes have been made to the schema.]


Regards,
Andrew Tipton

pgsql-general by date:

Previous
From: Ondrej Chaloupka
Date:
Subject: Incorrect response code after XA recovery
Next
From: saritha N
Date:
Subject: how to get UPDATEXML function in postgresql as it works in oracle