Estimado Alvaro mucha gracias por tú respuesta tengo algunas dudas:

Cuando dices que retorne un conjunto de resultados te refieres a un set of ?
Si es así, bueno no hice esto ya que crei que eso se hacía cuando queria que 
una función me retorne varios ref cursors de casos diferentes y tambien por que 
esta función es invocada desde C#, para mostrar los resultados obtenidos...

Además esta función ya esta implementada en el cliente y no quisiera tener que 
hacer una nueva funciòn de busqueda para que me retorne los códigos de 
personas, pero si no hay otra solución pues no tengo mas remedio que cambiar

De no ser el  caso quisiera me indiques como hago para que retorne un conjunto 
de resultados .

Ahora agradecería me indiquen con algún ejemplo como puedo recorrer esa 
varible, o si no es viable como debería programar para poder reutilziar las 
funciones de busqueda a continuación el código de la función per_sp_obt_persona


CREATE OR REPLACE FUNCTION "danmaf"."per_sp_obt_persona" (p_identificacion 
varchar, p_primer_nombre varchar, p_apellido_paterno varchar, p_razon_social 
varchar, p_cur_resultado "pg_catalog"."refcursor") RETURNS 
"pg_catalog"."refcursor" AS
$body$
declare
    v_persona INTEGER;
    v_desc_error "varchar"(200);
    BEGIN
    
    begin
    
    select count(1)
    into v_persona
    from danmaf.per_personas p
    where (p.identificacion=upper(p_identificacion) or upper(p_identificacion) 
is null)
    and (p.primer_nombre=upper(p_primer_nombre) or upper(p_primer_nombre) is 
null)
    and (p.apellido_paterno=upper(p_apellido_paterno) or 
upper(p_apellido_paterno) is null)
    and (p.razon_social like upper(p_razon_social)||'%' or 
upper(p_razon_social) is null);
    
    if v_persona=0 then
    open p_cur_resultado
    FOR select '-1403' as codigo, 'Error persona no se encuentra Registrada CI';
    return  p_cur_resultado;
    end if;
    
    end;
    
    if p_razon_social is null then
    
    open p_cur_resultado FOR
    
    select  
p.id_persona,p.identificacion,p.razon_social,p.primer_nombre,p.segundo_nombre,p.apellido_paterno,
    
p.apellido_materno,tel.numero,d.direccion,p.sexo,p.tipo_persona,p.tipo_identificacion,p.fecha_nacimiento,p.contribuyente_esp
    from  danmaf.per_telefono tel  right join
    danmaf.per_personas p on (tel.id_persona=p.id_persona ) left join 
danmaf.per_direcciones d   on (p.id_persona=d.id_persona )
    
    where (p.identificacion=upper(p_identificacion) or upper(p_identificacion) 
is null)
    and (p.primer_nombre=upper(p_primer_nombre) or upper(p_primer_nombre) is 
null)
    and (p.apellido_paterno=upper(p_apellido_paterno) or 
upper(p_apellido_paterno) is null)
    and (d.tipo ='D'  or d.tipo is null)
    and (tel.tipo ='D'  or tel.tipo is null);
    
    
    
    return  p_cur_resultado;
    --return;
    else
    
    open p_cur_resultado FOR
    select 
p.id_persona,p.identificacion,p.razon_social,p.primer_nombre,p.segundo_nombre,p.apellido_paterno,
    
p.apellido_materno,tel.numero,d.direccion,p.sexo,p.tipo_persona,p.tipo_identificacion,p.fecha_nacimiento,p.contribuyente_esp
    from  danmaf.per_telefono tel  right join
    danmaf.per_personas p on (tel.id_persona=p.id_persona ) left join 
danmaf.per_direcciones d   on (p.id_persona=d.id_persona )
    
    where p.razon_social like '%'||upper(p_razon_social)||'%'
    and (d.tipo = 'O' or d.tipo is null);
    
    return  p_cur_resultado;
    --return;
    
    end if;
    
    
    END;
$body$
LANGUAGE 'plpgsql' VOLATILE CALLED ON NULL INPUT SECURITY INVOKER;


Gracias por su ayuda




> Date: Sun, 7 Dec 2008 14:13:20 -0300
> From: [EMAIL PROTECTED]
> To: [EMAIL PROTECTED]
> CC: pgsql-es-ayuda@postgresql.org
> Subject: Re: Funciòn que devuelve un refcursor
> 
> ALFONSO REYES wrote:
> 
> > CREATE OR REPLACE FUNCTION "danmaf"."fac_obt_cab_factura" (p_identificacion
> > integer, p_fact_fisica varchar, p_fecha date, p_primer_nombre varchar,
> > p_apellido_paterno varchar, p_razon_social varchar) RETURNS
> > "pg_catalog"."refcursor" AS
> > $body$
> > DECLARE
> >  v_cur_resultado pg_catalog.refcursor;
> > BEGIN
> > 
> > begin
> > select danmaf.per_sp_obt_persona( p_identificacion, p_primer_nombre,
> > p_apellido_paterno, p_razon_social, v_cur_resultado);
> > 
> > end;
> > 
> > END;
> > $body$
> > LANGUAGE 'plpgsql' VOLATILE CALLED ON NULL INPUT SECURITY INVOKER;
> > 
> > Como pueden ver almaceno el cursor en la varible v_cur_resultado,
> > dentro de ese cursor hay un campo id_persona, necesito comparar o leer
> > ese campo contra otra tabla pero no se como hacer esoasi que si
> > alguien tiene una idea me ayudaría mucho.
> 
> Todo esto es muy confuso.  ¿Por qué estás usando un refcursor?  ¿Por qué
> no haces que per_sp_obt_persona retorne un conjunto de resultados común
> y corriente?
> 
> PD: la direccion de la lista es [EMAIL PROTECTED]  No
> envíes a pgsql-es-ayuda-owner a menos que sea algo administrativo.
> 
> -- 
> Alvaro Herrera                                http://www.CommandPrompt.com/
> The PostgreSQL Company - Command Prompt, Inc.

_________________________________________________________________
Connect to the next generation of MSN Messenger 
http://imagine-msn.com/messenger/launch80/default.aspx?locale=en-us&source=wlmailtagline

Reply via email to