Re: Trigger plpgsql function, how to test if OLD is set? - Mailing list pgsql-sql

From Tomasz Myrta
Subject Re: Trigger plpgsql function, how to test if OLD is set?
Date
Msg-id 3FCF7ECA.5060200@klaster.net
Whole thread Raw
In response to Trigger plpgsql function, how to test if OLD is set?  (Jeff Kowalczyk <jtk@yahoo.com>)
List pgsql-sql
Dnia 2003-12-04 19:18, Użytkownik Jeff Kowalczyk napisał:
> When this trigger runs on INSERT operations, the OLD variable is not
> yet set, and the trigger function returns an error.
> 
> Can anyone suggest a more sensible way to check for OLD before including
> it in my expression, or another shortcut? Thanks.
> 
> CREATE OR REPLACE FUNCTION orders_initordercharges () RETURNS "trigger"
>     AS '
> BEGIN
>   -- Check that no ordercharges exist for this orderid
>   IF (SELECT COUNT(orderchargeid) FROM ordercharges WHERE orderid=NEW.orderid OR orderid=OLD.orderid)=0 THEN
>     -- Insert standard initial set of ordercharges
>     INSERT INTO ordercharges (orderid, orderchargecode) VALUES (NEW.orderid,\'SALE\'); 
>     INSERT INTO ordercharges (orderid, orderchargecode) VALUES (NEW.orderid,\'S&H\'); 
>   END IF;
>   RETURN NEW;
> END;
> '
>     LANGUAGE plpgsql;

You can always check whether your trigger has been fired as insert or 
update trigger.

DECLARE  old_orderid  integer;
BEGIN  if TG_OP=''UPDATE'' then     old_orderid=OLD.orderid;  else     old_orderid=-1;  end if;
...

Regards,
Tomasz Myrta



pgsql-sql by date:

Previous
From: Tomasz Myrta
Date:
Subject: Re: How do I convert an interval into integer?
Next
From: Jeff Kowalczyk
Date:
Subject: Re: Trigger plpgsql function, how to test if OLD is set?