Ver Mensaje Individual
  #7  
Antiguo 10-07-2003
Aprendiz Aprendiz is offline
Miembro
 
Registrado: may 2003
Posts: 78
Reputación: 22
Aprendiz Va por buen camino
A ver un procedimiento almacenado es eso un procedimiento que guardas directamente en la base de datos.

Cuando quieres hacer una consulta muy bestia, o una función que te realice una serie de cálculo muy costosos, etc., en vez de hacerlo en local, creas un procedimiento almacenado (stored procedure) que realice esa función directamente en el servidor con lo que aceleras mucho la velocidad por que lo único que tu haces es llamar al procedimiento con los parámetros, si fuese necesario, y obtener directamente los resultados.

Un procedimiento almacenado puede hacer de todo, simplemente hacer unos cálculos y no devolver nada, o un solo resultado, o muchos. En el caso que quieras devolver muchos podemos aprovecharnos y utilizarlo como si fuese una tabla más de nuestra base de datos.

Cita:

Ejemplo:

set term /;
create procedure HOMOLOGACION
returns (HOMOLOGADO SMALLINT, CODIGO_PROVEEDOR VARCHAR(10))
as
begin
/* NO HOMOLOGADOS */
for select DISTINCT PRO.CODIGO_PROVEEDOR
from PROVEEDORES PRO
where (PRO.FECHA_CADUCIDAD<=F_DATE() or CER.FECHA_CADUCIDAD is null)
into :CODIGO_PROVEEDOR
do
begin
HOMOLOGADO=0;
SUSPEND;
end
/* HOMOLOGADOS */
for select DISTINCT PRO.CODIGO_PROVEEDOR
from PROVEEDORES PRO
where PRO.FECHA_CADUCIDAD>F_DATE()
into :CODIGO_PROVEEDOR
do
begin
HOMOLOGADO=1;
SUSPEND;
end
end;/
set term ;/
La clausula SUSPEND hace que el procedimiento devuelva los valores directamente como si de una tabla se tratase, así este procedimiento devolverá 'n' resultados.

Con este procedimiento podrias hacer cosas como:

SELECT CODIGO_PROVEEDOR,HOMOLOGADO
FROM HOMOLOGACION

Saludos
__________________
[Aprendiz]: Por que siempre hay algo nuevo que aprender.

Última edición por Aprendiz fecha: 10-07-2003 a las 15:19:11.
Responder Con Cita