From: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> |
---|---|
To: | Chris Mungall <cjm(at)fruitfly(dot)org> |
Cc: | pgsql-sql(at)postgresql(dot)org |
Subject: | Re: Calling SQL functions that return sets |
Date: | 2005-08-02 01:48:12 |
Message-ID: | 14685.1122947292@sss.pgh.pa.us |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-sql |
Chris Mungall <cjm(at)fruitfly(dot)org> writes:
> On Mon, 1 Aug 2005, Tom Lane wrote:
>> Chris Mungall <cjm(at)fruitfly(dot)org> writes:
>>> What are the reasons for deprecating the use of the function in the
>>> SELECT clause?
>>
>> The semantics of having more than one set-returning function in the
>> target list are, um, poorly thought out. However, we haven't removed
>> the feature because (as you note) there are things you can't do any
>> other way.
> Is there any roadmap for how this will be handled in future versions?
I think it's reasonably safe to say that we won't remove the feature for
at least one or two releases after having a 100% substitute (which the
present SRF-in-FROM feature is not, as you know). There has been some
speculation that the SQL:2003 LATERAL syntax might offer an adequate
substitute, but no one is really working on that yet AFAIK.
> Coming back to earth, I have a more specific question which follows on
> from my initial question. If I have a function 'foo' which takes one
> argument and returns a setof some table or composite type, it seems I am
> unable to call the function from the select clause.
> SELECT foo(1,2);
> ERROR: set-valued function called in context that cannot accept a set
The present plpgsql implementation only works for SRF-in-FROM. (Which
is something that could probably be fixed, but given the development
direction we want to go in, it doesn't seem like a very good use of
time...) You can do SRF-in-target-list with SQL-language functions or
C-coded functions; I'm not certain offhand about the status of the
other PL languages.
regards, tom lane
From | Date | Subject | |
---|---|---|---|
Next Message | Walker, Jed S | 2005-08-02 15:49:19 | Make year 01/01/0001 but leave timestamp alone |
Previous Message | Chris Mungall | 2005-08-02 01:14:22 | Re: Calling SQL functions that return sets |