On Wed, 26 Oct 2005, Mario Splivalo wrote:

> Consider this function:
>
> CREATE OR REPLACE FUNCTION php_get_subfield_data_repeating(int4,
> "varchar")
>   RETURNS SETOF "varchar" AS
> $BODY$
> DECLARE
>       aRecordID ALIAS FOR $1;
>       aSubFieldId ALIAS FOR $2;
>
>       returnValue record;
>       subFieldNumber char(3);
>       subFieldLetter char(1);
>
> BEGIN
>       subFieldNumber = substr(aSubFieldId, 1, 3);
>       subFieldLetter = substr(aSubFieldId, 4);
>
>       FOR returnValue IN SELECT "subfieldValue"::varchar
>                               FROM "records_sub"
>                               WHERE "fieldTag" = subFieldNumber AND 
> "subfieldTag" = subFieldLetter
> AND "recordId" = aRecordId
>       LOOP
>               RETURN NEXT returnValue;

I think the root cause is that you're not returning a varchar here, but
instead a record containing a varchar (if I return next
returnValue."subfieldValue" I don't seem to get parens).  I'm not sure why
it's allowing you to do so, though, it seems like that shouldn't match the
return type.

---------------------------(end of broadcast)---------------------------
TIP 4: Have you searched our list archives?

               http://archives.postgresql.org

Reply via email to