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