Re: Trigger violates foreign key constraint
От | Laurenz Albe |
---|---|
Тема | Re: Trigger violates foreign key constraint |
Дата | |
Msg-id | a3c8f66a2d89270eef77da9ba485949a49cdd8e9.camel@cybertec.at обсуждение исходный текст |
Ответ на | Trigger violates foreign key constraint (Laurenz Albe <laurenz.albe@cybertec.at>) |
Список | pgsql-hackers |
On Mon, 2023-10-02 at 09:49 -0400, Tom Lane wrote: > Laurenz Albe <laurenz.albe@cybertec.at> writes: > > CREATE FUNCTION silly() RETURNS trigger LANGUAGE plpgsql AS 'BEGIN RETURN NULL; END;'; > > CREATE TRIGGER silly BEFORE DELETE ON child FOR EACH ROW EXECUTE FUNCTION silly(); > > > The trigger function cancels the cascaded delete on "child", and we are left with > > a row in "child" that references no row in "parent". > > Yes. This is by design: triggers operate at a lower level than > foreign keys, so an ill-conceived trigger can break an FK constraint. > That's documented somewhere, though maybe not visibly enough. > > There are good reasons to want triggers to be able to see and > react to FK-driven updates, so it's unlikely that we'd want to > revisit that design decision, even if it hadn't already stood > for decades. Thanks for the clarification. I keep learning. I didn't find anything about that in the documentation or the READMEs in the source, but perhaps I didn't look well enough. Yours, Laurenz Albe
В списке pgsql-hackers по дате отправления: