Re: After Trigger assignment to NEW - Mailing list pgsql-sql

From Tom Lane
Subject Re: After Trigger assignment to NEW
Date
Msg-id 4347.1140802671@sss.pgh.pa.us
Whole thread Raw
In response to Re: After Trigger assignment to NEW  (Alvaro Herrera <alvherre@commandprompt.com>)
Responses Re: After Trigger assignment to NEW
List pgsql-sql
Alvaro Herrera <alvherre@commandprompt.com> writes:
> Tom Lane wrote:
>> Achilleus Mantzios <achill@matrix.gatewaynet.com> writes:
>>> Is there a reason that the NEW values should remain unchanged in AFTER 
>>> row triggers?
>> 
>> By definition, an AFTER trigger is too late to change what was stored.
>> Use a BEFORE trigger.

> But a BEFORE trigger would alter the stored tuple, which is not what
> Achilleus wants AFAIU.

Oh, I misunderstood what he wanted ... and now that I do understand,
I think it's a really terrible idea :-(.  A large part of the point
of using an AFTER trigger is to be certain you know exactly what got
stored.  (BEFORE triggers can never know this with certainty because
there might be another BEFORE trigger that runs after them and edits the
tuple some more.)  If one AFTER trigger could falsify the data seen by
the next, then that guarantee crumbles.  For instance, a minor
programming error in a user-written trigger could break foreign-key
checking.  No thanks.

> I think the desired effect can be had by having DBMirror check the
> source relation of the inserted tuple (There is a hidden attributa
> called tableoid IIRC that can be used for that, I think).

I agree --- the correct solution is to change the DBMirror triggers to
incorporate the desired filtering logic.
        regards, tom lane


pgsql-sql by date:

Previous
From: Alvaro Herrera
Date:
Subject: Re: After Trigger assignment to NEW
Next
From: "Daniel Hernandez"
Date:
Subject: Missing fields on Query result.