Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Conexión con bases de datos (https://www.clubdelphi.com/foros/forumdisplay.php?f=2)
-   -   Rollback de trigger si falla mi transacción (https://www.clubdelphi.com/foros/showthread.php?t=95301)

ethangio 21-07-2021 22:33:56

Rollback de trigger si falla mi transacción
 
Buen día, agradezco el tiempo que te tomas para leer mi problema, espero opines o me des un indicio para resolverlo.

Tengo 3 insert a diferentes tablas mysql (t1, t2, t3) mediante una transacción debido a que se relacionan por medio de un folio y deben insertarse los 3 o ninguno.

En t2 tengo un trigger after insert.

Entonces si mi transacción falla en el insert t3 mi trigger en t2 ya se ejecutó, al hacer rollback no se inserta la información en t1,t2 y t3 pero mi trigger ya hizo su tarea.

Cómo puedo hacer rollback en mi trigger si mi transacción hace rollback ?


Gracias de antemano. Saludos.

Casimiro Notevi 22-07-2021 11:01:44

En teoría, con cualquier base de datos que cumpla con las normas sql (firebird, postgresql, oracle, mssql, etc.) no tendrías que hacer nada, supongo que será alguna característica de mysql.

Me parece recordar que mysql tiene varias "formas" distintas de trabajar, seguramente va por ahí el asunto.

Neftali [Germán.Estévez] 22-07-2021 11:40:15

¿Con qué BBDD estás trabajando?
Lo lógico tal como comenta [Casimiro] es que si los INSERT van en la misma transacción, los triggers asociados se incluyan en esa misma transacción, por lo tanto, el rollback debería deshacerlo todo.

ethangio 22-07-2021 19:48:57

Gracias Casimiro y gracias Neftalí por sus respuestas.

Neftalí estoy trabajando con MySQL.

Leyendo sus comentarios recordé que las transacciones en MySQL las tablas deben ser InnoDB y mis 3 tablas (t1,t2 y t3) si son pero el trigger en t2 que envía información a otra tabla después del insert es MyISAM entonces pienso que pudiese ser que por eso el rollback no se aplica en ella.

Mi código delphi no tiene nada de extra ordinario:

Código Delphi [-]
      // Inicia la TRANSACCION 
      ZServidor.StartTransaction;

      try
      // Envío la info del cobro al Servidor
      // hostname es el nombre del servidor a donde se va a enviar la información

      tabla := 'cobro';
      TransactionOfInformation(tabla, ZLQuery1.FieldByName('hostname').AsString); 

      // Envío la info de la movimiento al Servidor
      tabla := 'movimiento';
      TransactionOfInformation(tabla, ZLQuery1.FieldByName('hostname').AsString);

      // Envío la info del detalle del movimiento al Servidor
      tabla := 'detalle';
      TransactionOfInformation(tabla, ZLQuery1.FieldByName('hostname').AsString);

      ZServidor.Commit;
      except on E: Exception do
        begin 
           ZServidor.Rollback;
           ShowMessage(E.ClassName+' error raised, with message : '+E.Message+#10#13+
           'Si continúa recibiendo éste error DETENGA el SERVICIO');
        end;
      end;


Y el trigger en la tabla detalle envía información a otra tabla que es MyISAM que concentra datos para reportes.
Cambiaré el motor de almacenamiento, haré pruebas y les comento.

Muchas gracias por su tiempo.

Casimiro Notevi 22-07-2021 20:07:46

Cita:

Empezado por ethangio (Mensaje 542046)
Leyendo sus comentarios recordé que las transacciones en MySQL las tablas deben ser InnoDB y mis 3 tablas (t1,t2 y t3) si son pero el trigger en t2 que envía información a otra tabla después del insert es MyISAM entonces pienso que pudiese ser que por eso el rollback no se aplica en ella.


Efectivamente, a eso me refería con este comentario:
Cita:

Empezado por Casimiro Notevi (Mensaje 542020)
Me parece recordar que mysql tiene varias "formas" distintas de trabajar, seguramente va por ahí el asunto.

A ver si es eso.

ethangio 22-07-2021 23:19:14

Gracias infinitas :)

Las tablas deben ser InnoDB para que el rollback las afecte.

Éste hilo se puede cerrar.

Saludos y nuevamente gracias por su tiempo.


La franja horaria es GMT +2. Ahora son las 19:09:56.

Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi