Re: Disabling Triggers - Mailing list pgsql-general

From Richard Huxton
Subject Re: Disabling Triggers
Date
Msg-id 42822A6B.5020404@archonet.com
Whole thread Raw
In response to Disabling Triggers  ("Mark Borins" <mark.borins@rigadev.com>)
Responses Re: Disabling Triggers  ("Mark Borins" <mark.borins@rigadev.com>)
List pgsql-general
Mark Borins wrote:
> I am creating a system where I have a trigger on three different tables.
> There is a particular Boolean field in each of these tables that when it is
> set in table it should be set the same in the other two.

Just make sure you only check the boolean value too:

-- Trigger on table a does:
IF NEW.my_bool=OLD.my_bool THEN
   RETURN NEW;
END IF;

UPDATE b SET my_bool=NEW.my_bool
   WHERE id=NEW.something AND my_bool <> NEW.my_bool
UPDATE c SET my_bool=NEW.my_bool
   WHERE id=NEW.something AND my_bool <> NEW.my_bool
-- End code

That way, you always do the minimal amount of work anyway.
--
   Richard Huxton
   Archonet Ltd

pgsql-general by date:

Previous
From: Richard Huxton
Date:
Subject: Re: JOIN on set of rows?
Next
From: Tom Lane
Date:
Subject: Re: alter table owner doesn't update acl information