Re: Trigger plpgsql function, how to test if OLD is set?

From: Tomasz Myrta <jasiek(at)klaster(dot)net>
To: Jeff Kowalczyk <jtk(at)yahoo(dot)com>
Cc: pgsql-sql(at)postgresql(dot)org
Subject: Re: Trigger plpgsql function, how to test if OLD is set?
Date: 2003-12-04 18:36:58
Message-ID: 3FCF7ECA.5060200@klaster.net
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: 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

In response to

Responses

Browse pgsql-sql by date

  From Date Subject
Next Message Jeff Kowalczyk 2003-12-04 19:24:29 Re: Trigger plpgsql function, how to test if OLD is set?
Previous Message Tomasz Myrta 2003-12-04 18:26:08 Re: How do I convert an interval into integer?