Re: Problem with return type of function ??? (corrected) - Mailing list pgsql-sql

From Denis BUCHER
Subject Re: Problem with return type of function ??? (corrected)
Date
Msg-id 4AE06E75.9010305@hsolutions.ch
Whole thread Raw
In response to Re: Problem with return type of function ??? (corrected)  (Tom Lane <tgl@sss.pgh.pa.us>)
List pgsql-sql
Hello Tom,

Tom Lane a écrit :
> Denis BUCHER <dbucherml@hsolutions.ch> writes:
>> I have a strange problem, because it worked in a fonction for a table,
>> and now I created the same (?) function for another table and it doesn't
>> work...
> 
>> The function is accepted but at runtime I get :
> 
>> ERREUR:  wrong record type supplied in RETURN NEXT
>> CONTEXTE : PL/pgSQL function "find_sn_live" line 26 at return next
> 
> Does that table have any dropped columns?  If you don't remember
> whether you ever dropped any columns, a quick look into pg_attribute
> will tell you:
> select attname from pg_attribute where attrelid = 'rma.serial_number'::regclass;

Yes !
          attname

------------------------------tableoidcmaxxmaxcminxminctidsn_idsnno_clientno_art_bwsn_fc_date........pg.dropped.6................pg.dropped.7........desc_frsn_cm_dateno_factureno_commande
(17 lignes)

> plpgsql isn't tremendously good with rowtypes that contain dropped
> columns.  I believe this particular case is fixed in CVS HEAD, but the
> patch was a bit invasive and won't get back-ported to existing releases.
> The workaround is to drop and recreate the table without any dropped
> columns.

OH, I see...

Thanks a lot, I will try this later today when nobody uses the
application...


Denis


pgsql-sql by date:

Previous
From: Denis BUCHER
Date:
Subject: Re: Problem with return type of function ???
Next
From: Richard Huxton
Date:
Subject: Re: Problem with return type of function ???