From: | "David G(dot) Johnston" <david(dot)g(dot)johnston(at)gmail(dot)com> |
---|---|
To: | Nicolas Mitchell <mitchelln(at)posteo(dot)net> |
Cc: | hubert depesz lubaczewski <depesz(at)depesz(dot)com>, "pgsql-novice(at)lists(dot)postgresql(dot)org" <pgsql-novice(at)lists(dot)postgresql(dot)org> |
Subject: | Re: Trigger function |
Date: | 2021-07-27 22:13:22 |
Message-ID: | CAKFQuwazmQBDYdt+zcw2WV+3bONRjbe7qoHiMnREYj+VRXEXjA@mail.gmail.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-novice |
On Tuesday, July 27, 2021, Nicolas Mitchell <mitchelln(at)posteo(dot)net> wrote:
>
> But when I have tried this with the following trigger/function
> (BEFORE/AFTER), PG goes into a loop. The two associated sequences (object,
> host) are incremented until I break the execution but no insert happens in
> either table. My code is causing an endless loop. I’m too green to
> understand why! I’d be grateful for any hints to help me on my way.
>
> CREATE OR REPLACE FUNCTION public.func__host__bi()
> RETURNS trigger AS
> $$
> begin
>
> INSERT INTO host (name, domain, object)
> VALUES (NEW.name, NEW.domain, (SELECT * FROM object_id));
> RETURN NEW;
> end
> $$
> LANGUAGE 'plpgsql'
>
> CREATE TRIGGER trig__host_bi
> BEFORE INSERT <————————————> or AFTER INSERT
> ON public."host"
> FOR EACH ROW
> EXECUTE PROCEDURE public.func__host__bi();
>
You are getting an infinite cycle because while in the middle of inserting
a row into host, which provokes the trigger, you go and execute another
insert command for host, provoking the same trigger, performing yet another
insert, provoking the same trigger, etc…
When you write a trigger for a table you should be executing commands
against the same table.
You change the data in the ongoing insert by returning a different row from
the trigger function (i.e., modify your “return new;” line - or modify NEW
itself?).
David J.
From | Date | Subject | |
---|---|---|---|
Next Message | David G. Johnston | 2021-07-27 22:15:16 | Re: Trigger function |
Previous Message | Nicolas Mitchell | 2021-07-27 21:05:26 | Re: Trigger function |