Foros del Web » Programando para Internet » PHP »

[Pregunta] Otro Metodo para un RollBack en Dos Sentencia.

Estas en el tema de [Pregunta] Otro Metodo para un RollBack en Dos Sentencia. en el foro de PHP en Foros del Web. Buenas, Bueno mi pregunta es la siguiente, tengo un problema al hacer dos setencias sql (INSERT) ya que una depende de la otra. ejemplo creas ...
  #1 (permalink)  
Antiguo 07/11/2008, 14:13
 
Fecha de Ingreso: noviembre-2004
Mensajes: 43
Antigüedad: 19 años, 6 meses
Puntos: 0
Pregunta [Pregunta] Otro Metodo para un RollBack en Dos Sentencia.

Buenas,

Bueno mi pregunta es la siguiente, tengo un problema al hacer dos setencias sql (INSERT) ya que una depende de la otra.

ejemplo creas un cliente y de repente se crea un cuenta a ese cliente.

Tabla 1
codigo
nombre

Tabla 2
numero
descripcion
Balance
codigo (foreignkey de tabla1)

al insertar un registro en tabla 1 se debera crear otro registro en tabla 2 con el codigo que se acabo de registrar en Tabla 1.

Como podria controlar eso? que solo se inserten si pueden insertarse las dos.

por que me ha pasado que se inserta la primera y la segunda da error

he oido del rollback. pero solo quiero usar esto para esta tabla. no para toda la base de datos. otra cosa es que si activo esto (no se como activarlo), siempre deberia hacer
begin
sql
commit/rollback ??

osea que deberia modificar todo mi codigo?


Saludos~


Edit:

Un Ejemplo de como se me ocurre es.
si el primero se inserta trato de insertar el segundo si se hace tonces todo bien
si el primero no se inserta no trato de insertar el segundo tonces error
si el primero inserta pero el segundo me da error, eliminar el mysql_insert_id

estaria bien de esa manera o habria una mejor manera?
  #2 (permalink)  
Antiguo 07/11/2008, 14:23
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 18 años
Puntos: 2135
Respuesta: [Pregunta] Otro Metodo para un RollBack en Dos Sentencia.

Hola wellimp,

En primera tus tablas tendrian que ser InnoDB (si usas MySQL), posteriormente MySQL trabaja en autocommit mode, por lo que para iniciar una transaccion tendrias que manualmente y explicitamente hacer un START TRANSACTION, y en caso de error hacer el ROLLBACK, y si no hay errores hacer el COMMIT.

Saludos.
  #3 (permalink)  
Antiguo 07/11/2008, 14:58
 
Fecha de Ingreso: noviembre-2004
Mensajes: 43
Antigüedad: 19 años, 6 meses
Puntos: 0
Exclamación Respuesta: [Pregunta] Otro Metodo para un RollBack en Dos Sentencia.

Cita:
Iniciado por GatorV Ver Mensaje
Hola wellimp,

En primera tus tablas tendrian que ser InnoDB (si usas MySQL), posteriormente MySQL trabaja en autocommit mode, por lo que para iniciar una transaccion tendrias que manualmente y explicitamente hacer un START TRANSACTION, y en caso de error hacer el ROLLBACK, y si no hay errores hacer el COMMIT.

Saludos.
Bueno eso quiere decir que todo lo demas Sql que tenga tendria que agregarle todo eso.

y bien como se que la tabla son InnoDB? pero autocommit mode es una opcion general o una opcion por tablas?

Saludos~
  #4 (permalink)  
Antiguo 07/11/2008, 16:28
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 18 años
Puntos: 2135
Respuesta: [Pregunta] Otro Metodo para un RollBack en Dos Sentencia.

Es por conexión y esta activada por defecto, no necesitas cambiar tus querys actuales, solo en donde quieras hacer la transacción.

Saludos.
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 21:45.