Re: BUG #15106: The AFTER trigger is created separately on view, andthe DML operation can not trigger the trigger - Mailing list pgsql-bugs

From Thomas Munro
Subject Re: BUG #15106: The AFTER trigger is created separately on view, andthe DML operation can not trigger the trigger
Date
Msg-id CAEepm=0UZpJMR26VBXM6a_1N-Q75m4=6L5+uEk=ky+7AnNknow@mail.gmail.com
Whole thread Raw
In response to Re: BUG #15106: The AFTER trigger is created separately on view, and the DML operation can not trigger the trigger  (Tom Lane <tgl@sss.pgh.pa.us>)
Responses Re: BUG #15106: The AFTER trigger is created separately on view, and the DML operation can not trigger the trigger  (Tom Lane <tgl@sss.pgh.pa.us>)
List pgsql-bugs
On Tue, Mar 13, 2018 at 9:27 AM, Tom Lane <tgl@sss.pgh.pa.us> wrote:
> =?utf-8?q?PG_Bug_reporting_form?= <noreply@postgresql.org> writes:
>> It can be seen from the above example, the DML operation cannot trigger the
>> trigger when the Statement-level AFTER trigger is created on view alone.
>> But when create INSTEAD OF trigger at the same time, the DML operation can
>> trigger the AFTER trigger.
>
> When there's no INSTEAD OF trigger, the query is rewritten into an insert
> on the view's base table (assuming the view is simple enough to be
> auto-updatable), and we fire the base table's statement triggers, not the
> view's.  I'm pretty sure this is intentional, though I couldn't find it
> mentioned in the manual either.  Firing both sets of statement triggers
> would be confusing, and not firing the base table's triggers would
> perhaps miss processing that needs to happen.

We also discussed this here:

https://www.postgresql.org/message-id/flat/CACjxUsOrn%2B3FgaLzskuLB3hASW6iTUd6f40gq_q80a9NHXk92A%40mail.gmail.com

We resolved the main issue in that thread but we didn't do anything
about this side issue.  You and Kevin both suggested that perhaps we
shouldn't allow you to create such unfireable triggers, or perhaps we
should raise a warning, or at least document the (IMHO) confusing
behaviour.

-- 
Thomas Munro
http://www.enterprisedb.com


pgsql-bugs by date:

Previous
From: Tom Lane
Date:
Subject: Re: Weird return-value from pg_get_function_identity_arguments() on certain aggregate functions?
Next
From: Patrick Krecker
Date:
Subject: Re: BUG #15104: Double free in the main function in ecpg.c