Perdón, me respondo yo solo:

select
    pos_email,
    pos_apellido,
    pos_nombre,
    *string_agg*(edu_titulo, '<BR>')
from postulantes inner join titulos using(pos_id)
group by
    pos_email,
    pos_apellido,
    pos_nombre
Debía utilizar en 9.0 la función *string_agg*

Guillermo Villanueva




El 7 de agosto de 2012 08:49, Guillermo Villanueva
<[email protected]>escribió:

> Buenos días, estaba buscando si existe una función agregada no estándar
> tal que así como se puede hacer un sum() de valores numéricos, pueda
> concatenar valores de tipo varchar.
> No encontré algo así, pero encontré una alternativa que la pongo a
> consideración de uds.
>
> Supongamos el siguiente caso: tengo una tabla de postulantes (personas) y
> otra de los títulos o estudios. Titulos tiene una FK apuntando a
> postulantes, entonces quiero listar todos los posulantes y por cada uno de
> estos la concatenación de las filas de títulos que tenga.
> Yo pretendía algo así:
>
> select
>     pos_email,
>     pos_apellido,
>     pos_nombre,
>     sumvarchar(edu_titulo||'<BR>')
> from postulantes inner join titulos using(pos_id)
> group by
>     pos_email,
>     pos_apellido,
>     pos_nombre
>
> Pero como sumvarchar no existe
> Hice lo siguiente:
>
> select
>     pos_email,
>     pos_apellido,
>     pos_nombre,
>     array_to_string(array(select edu_titulo from educacion where
> pos_email=a.pos_email),'<BR>')
> from postulantes a
>
> Por favor, cuentenmé si hay alguna forma mas eficiente de hacerlo.
> Desde ya muchas gracias
>
> Guillermo Villanueva
>
>
>

Responder a