Ver Mensaje Individual
  #6  
Antiguo 13-04-2012
Avatar de duilioisola
[duilioisola] duilioisola is offline
Miembro Premium
 
Registrado: ago 2007
Ubicación: Barcelona, España
Posts: 1.734
Reputación: 20
duilioisola Es un diamante en brutoduilioisola Es un diamante en brutoduilioisola Es un diamante en bruto
El problema es que todo el bloque que "puede fallar" debe ir entre un begin y un end.
Tiene que ver con las trasacciones.
No recuerdo donde lo lei, pero parece ser que lo que va entre en un bloque, se realiza en una transacción y asi pueden capturarse.

Esto si funciona, (lo he probado, FB 1.5):

Código SQL [-]
create procedure AAA_PRUEBA
returns (errores integer)
as
declare variable instruccion varchar(100);
begin
   /* Cantidad de errores */
   errores = 0;

   /* SQL a ejecutar */
   begin
       instruccion = 'ALTER TABLE TTT ADD CAMPO2 INTEGER';
       execute statement instruccion ;
       /* Capturo la excepcion */
       /* ANY es cualquier excepcion */
       /* Tambien se pueden poner los valores de cada excepcion individual */
       when any do
       begin
           errores = errores + 1;
           exception err_breakpoint 'Hubo un error haciendo ' || instruccion ;
       end
   end

   /* Hago mas cosas si no huno errores */
   if (errores = 0) then
   begin
       instruccion = 'UPDATE TTT SET CAMPO2=0';
       execute statement instruccion ;
       /* Capturo la excepcion nuevamente */
       when any do
       begin
           errores = errores + 1;
           exception err_breakpoint 'Hubo un error haciendo ' || instruccion ;
       end
   end

   suspend;
end
Responder Con Cita