From: | Jasen Betts <jasen(at)xnet(dot)co(dot)nz> |
---|---|
To: | pgsql-sql(at)postgresql(dot)org |
Subject: | Re: very frustrating feature-bug |
Date: | 2010-02-17 10:51:04 |
Message-ID: | hlghmo$3g2$2@reversiblemaps.ath.cx |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-sql |
On 2010-02-17, silly sad <sad(at)bankir(dot)ru> wrote:
>
> acc=>
>
> CREATE OR REPLACE FUNCTION add_user (TEXT, TEXT, TEXT, TEXT)
> RETURNS usr AS $$
> INSERT INTO usr (login,pass,name,email) VALUES ($1,$2,$3,$4)
> RETURNING usr.*;
> $$ LANGUAGE sql SECURITY DEFINER;
>
> acc=>
>
> ERROR: return type mismatch in function declared to return usr
> DETAIL: Function's final statement must be a SELECT.
> CONTEXT: SQL function "add_user"
>
> SURPRISE :-) SURPRISE :-)
SQL functions are inlined when invoked, and so must be valid subselects.
rewrite it in plpgsql.
CREATE OR REPLACE FUNCTION add_user (TEXT, TEXT, TEXT, TEXT)
RETURNS usr AS $$
DECLARE
retval usr;
BEGIN
INSERT INTO usr (login,pass,name,email) VALUES ($1,$2,$3,$4)
RETURNING usr.* INTO retval;
RETURN retval;
END;
$$ LANGUAGE PLPGSQL SECURITY DEFINER;
From | Date | Subject | |
---|---|---|---|
Next Message | silly sad | 2010-02-17 11:34:25 | Re: very frustrating feature-bug |
Previous Message | silly sad | 2010-02-17 07:20:15 | very frustrating feature-bug |