Re: function error - Mailing list pgsql-sql

From Jeff Eckermann
Subject Re: function error
Date
Msg-id 20020328153525.78708.qmail@web20806.mail.yahoo.com
Whole thread Raw
In response to function error  ("Travis Hoyt" <thoyt@npc.net>)
Responses Re: function error
List pgsql-sql
If this is genuinely a copy of something in the
"PostgreSQL Developer's Handbook", then that book
could use some work.
1. You need "ALIAS FOR" in the DECLARE section
2. You need an explicit RETURN; i.e. write "RETURN
result;" before "END;"
3. Language is plpgsql, not sql (which doesn't allow
the constructions you are using).

If columns "systemid" and "time" are not of text type,
you will need to do some type casting for your
comparisons to work.  I believe "time" is a reserved
word anyway, so if that is the real name of the
column, you will need to double-quote it, which in the
function definition will need to be escaped:
'"time"', or \"time\".

--- Travis Hoyt <thoyt@npc.net> wrote:
> CREATE FUNCTION biwklyavg(text, text, text) RETURNS
> numeric AS '
>         DECLARE
>                 system          ALIAS $1;
>                 startdate       ALIAS $2;
>                 enddate         ALIAS $3;
>                 result          numeric;
> 
>         BEGIN
>                 result := (select (avg(usr) +
> avg(sys)) from sardata where
> systemid = system
>                         and time between startdate
> and enddate;
>         END;
> ' LANGUAGE 'sql';
> 
> Hello,
> 
> The fuction listed above gives the following error:
> 
> ERROR:  parser: parse error at or near "alias"
> 
> I'm running v7.2.  Any ideas?  I pulled this
> directly from the examples in
> the PostgreSQL Developer's Handbook.
> 
> Thanks,
> 
> Travis
> 

> ATTACHMENT part 2 application/x-pkcs7-signature
name=smime.p7s



__________________________________________________
Do You Yahoo!?
Yahoo! Movies - coverage of the 74th Academy Awards�
http://movies.yahoo.com/


pgsql-sql by date:

Previous
From: DI Hasenöhrl
Date:
Subject: Re: Left outer join with WHERE clause?
Next
From: "Travis Hoyt"
Date:
Subject: Re: function error