From: | Merlin Moncure <mmoncure(at)gmail(dot)com> |
---|---|
To: | Tarlika Elisabeth Schmitz <postgresql6(at)numerixtechnology(dot)de> |
Cc: | pgsql-general <pgsql-general(at)postgresql(dot)org> |
Subject: | Re: [PL/pgSQL] function call |
Date: | 2011-10-31 14:41:40 |
Message-ID: | CAHyXU0yHg=4hTmsSqAUJSYapN_T_6td8YX8VJUeiC_2AEfMwtg@mail.gmail.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-general |
On Mon, Oct 31, 2011 at 8:31 AM, Tarlika Elisabeth Schmitz
<postgresql6(at)numerixtechnology(dot)de> wrote:
> I have created a function log_insert(), which is simply a shorthand for
> an INSERT table and which I want to call from various trigger functions.
>
> CREATE OR REPLACE FUNCTION log_insert(vseverity text, vtrigger text,
> vtriggertable text, vtriggerid text, vmessage text) RETURNS boolean AS
> $BODY$
> BEGIN
> INSERT INTO log
> (severity, trigger,triggertable, triggerid, message)
> VALUES
> (vseverity, vtrigger,vtriggertable, vtriggerid, vmessage);
> END
> $BODY$
> LANGUAGE plpgsql VOLATILE;
>
>
> I tried:
> log_insert('I', TG_NAME, TG_TABLE_NAME, NEW.id, 'some msg');
> => I get a syntax error on CREATE TRIGGER.
>
> SELECT log_insert(...)
> => passes the syntax check but throws an error when run:
> "function log_insert(unknown, unknown, unknown, integer, unknown) does
> not exist Hint: No function matches the given name and argument types.
> You might need to add explicit type casts."
>
>
> Any help would be greatly appreciated.
There is some context you are not passing here -- the log_insert
function is being inside a trigger function which is where your error
always is. However, in pl/pgsql, you always call functions with
PERFORM or SELECT depending if you want to process the result.
also, FWIW, I don't like a simple wrapper for insert statement like
that -- the syntax brevity is outweighed by the loss of SQL features
such as being able to pass DEFAULT for columns.
merlin
From | Date | Subject | |
---|---|---|---|
Next Message | Pavel Stehule | 2011-10-31 15:01:53 | Re: [PL/pgSQL] function call |
Previous Message | hubert depesz lubaczewski | 2011-10-31 14:06:14 | Re: Why is there no 8.3.16 rpm with _id ? |