| From: | Tobia Conforto <tobia(dot)conforto(at)gruppo4(dot)eu> |
|---|---|
| To: | pgsql-general(at)postgresql(dot)org |
| Subject: | Re: Multi-row constraints, how to avoid unnecessary trigger execution? |
| Date: | 2016-04-06 17:00:05 |
| Message-ID: | 2DC89567-68C7-436B-ABBC-28CA8692007F@gruppo4.eu |
| Views: | Whole Thread | Raw Message | Download mbox | Resend email |
| Thread: | |
| Lists: | pgsql-general |
Sándor,
I'd rather have the application developers use regular DML, which could become quite complex, and just perform my check on the database side, at transaction commit time.
Andreas,
thanks, but I need to avoid duplicate executions on different rows too.
I just came up with this "hack" which seems to be working:
create or replace function my_trigger() returns trigger as $$
begin
create temporary table my_trigger() on commit drop;
-- perform expensive test here and raise error if it fails
if ... then
raise ...;
end if;
return null;
exception when duplicate_table then
-- already ran in the current transaction, skip test
return null;
end;
$$ language 'plpgsql';
create constraint trigger my_trigger after insert or update or delete on my_table
initially deferred for each row execute procedure my_trigger();
Any improvement is welcome.
-Tobia
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Andreas Joseph Krogh | 2016-04-06 17:44:16 | Re: Multi-row constraints, how to avoid unnecessary trigger execution? |
| Previous Message | Andreas Joseph Krogh | 2016-04-06 16:54:49 | Re: Multi-row constraints, how to avoid unnecessary trigger execution? |