On Aug 16, 2011, at 14:29, Merlin Moncure <mmonc...@gmail.com> wrote:

> On Tue, Aug 16, 2011 at 8:33 AM, Harald Fuchs <hari.fu...@gmail.com> wrote:
>> In article 
>> <cakwofmjwz3znxcj9radn4ov+krsa-133968yvag3l8m3w3z...@mail.gmail.com>,
>> Lauri Kajan <lauri.ka...@gmail.com> writes:
>> 
>>> I have also tried:
>>> select
>>> *, getAttributes(a.id)
>>> from
>>>   myTable a
>> 
>>> That works almost. I'll get all the fields from myTable, but only a
>>> one field from my function type of attributes.
>>> myTable.id | myTable.name | getAttributes
>>> integer      | character        | attributes
>>> 123           | "record name" | (10,20)
>> 
>>> What is the right way of doing this?
>> 
>> If you want the attributes parts in extra columns, use
>> 
>> SELECT *, (getAttributes(a.id)).* FROM myTable a
> 
> This is not generally a good way to go.  If the function is volatile,
> you will generate many more function calls than you were expecting (at
> minimum one per column per row).  The best way to do this IMO is the
> CTE method (as david jnoted) or, if and when we get it, 'LATERAL'.
> 

>From your statement is it correct to infer that a function defined as "stable" 
>does not exhibit this effect?  More specifically would the function only be 
>evaluated once for each set of distinct parameters and the resulting 
>records(s) implicitly cached just like the CTE does explicitly?

David J.
-- 
Sent via pgsql-general mailing list (pgsql-general@postgresql.org)
To make changes to your subscription:
http://www.postgresql.org/mailpref/pgsql-general

Reply via email to