![]() |
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. |
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. |
¿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. |
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:
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. |
Cita:
Efectivamente, a eso me refería con este comentario: Cita:
|
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 18:59:42. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi