From: | KÖPFERL Robert <robert(dot)koepferl(at)sonorys(dot)at> |
---|---|
To: | "'A(dot) Kulikov'" <a(dot)kulikov(at)gmail(dot)com> |
Cc: | pgsql-sql(at)postgresql(dot)org |
Subject: | Re: User Defined Functions Errors |
Date: | 2005-04-19 07:23:46 |
Message-ID: | ED4E30DD9C43D5118DFB00508BBBA76EB166BB@neptun.sonorys.at |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-sql |
Have a try with RAISE NOTE or RAISE EXCEPTION
keep in mind that exceptions should be exceptional. So a good idea of
whether to use them is to ask 'Do I expect such error' or 'is an explicit
error useful for the caller'. I'ts often better to just return an empty
relation
|-----Original Message-----
|From: A. Kulikov [mailto:a(dot)kulikov(at)gmail(dot)com]
|Sent: Montag, 18. April 2005 20:32
|To: pgsql-sql(at)postgresql(dot)org
|Subject: [SQL] User Defined Functions Errors
|
|
|How to I return an error from inside a user defined function? For
|example the following:
|
|CREATE or REPLACE FUNCTION drop_node (integer) RETURNS text
|AS '
|
|DECLARE
|
|mleft INTEGER;
|mright INTEGER;
|
|BEGIN
|
|-- Check if the desired node exists
|SELECT lft, rgt FROM structure WHERE id = $1 INTO mleft, mright;
|
|IF mleft IS NULL THEN
| RETURN ''No entry found with an id of ''||$2;
|END IF;
|
|-- Drop the node and its subtree
|DELETE FROM structure WHERE lft >= mleft AND rgt <= mright;
|
|-- Close the gap
|UPDATE structure SET rgt = rgt - (mright - mleft + 1) WHERE
|rgt > mright;
|UPDATE structure SET lft = lft - (mright - mleft + 1) WHERE
|lft > mleft;
|
|RETURN ''ok'';
|
|END;
|'
|LANGUAGE 'plpgsql';
|
|Should be terminated with an error @ RETURN "No Entry found"; instead
|of returning the error text.
|
|best regards and thanks,
|
|Alex
|--
|The mind is essential -- http://essentialmind.com/
|
|---------------------------(end of
|broadcast)---------------------------
|TIP 4: Don't 'kill -9' the postmaster
|
From | Date | Subject | |
---|---|---|---|
Next Message | KÖPFERL Robert | 2005-04-19 07:34:43 | Re: can a function return a virtual table? |
Previous Message | Ramakrishnan Muralidharan | 2005-04-19 07:12:45 | Re: SQL subquery (count distinct) - Any Ideas? |