Ver Mensaje Individual
  #2  
Antiguo 02-09-2011
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Reputación: 26
guillotmarc Va por buen camino
Esto es un ejemplo perfecto de un proceso que se ejecuta muchísimo más rápido en un procedimiento almacenado.

Sería más o menos así :

Código SQL [-]
SET TERM ^ ;

create procedure ACTUALIZAR_SALDO
returns (
    TOTAL_SALDO numeric(15,2),
    TOTAL_DEBE numeric(15,2),
    TOTAL_HABER numeric(15,2))
as
declare variable MOV_ID integer;
declare variable MOV_DEBE numeric(15,2);
declare variable MOV_HABER numeric(15,2);
begin
  TOTAL_SALDO = 0;
  TOTAL_DEBE = 0;
  TOTAL_HABER = 0;

  for select ID, coalesce(DEBE,0), coalesce(HABER,0)
      from MOVIMIENTOS
      into :MOV_ID, :MOV_DEBE, :MOV_HABER
  do begin
    TOTAL_SALDO = TOTAL_SALDO + MOV_DEBE - MOV_HABER;
    TOTAL_DEBE = TOTAL_DEBE + MOV_DEBE;
    TOTAL_HABER = TOTAL_HABER + MOV_HABER;

    update MOVIMIENTOS set
           SALDO = :TOTAL_SALDO
    where ID = :MOV_ID;
  end
end
^

SET TERM ; ^

Al ejecutarse todo el procedimiento almacenado en el servidor, te ahorras todo el movimiento de red necesario para recorrer los 2.000 registros, recuperar los valores de sus campos, modificar el registro, etc. ...

El paso por la red suele ser el cuello de botella de estos procesos. Mediante la ejecución en un procedimiento almacenado, por la red solo se pasa la solicitud de ejecución del procedimiento almacenado, y se reciben como resultado los valores de Saldo, Debe y Haber Totales.

Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no).
Responder Con Cita