Re: very frustrating feature-bug

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;

In response to

Responses

Browse pgsql-sql by date

  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