Foros del Web » Programando para Internet » PHP »

Error en el beginTransaction

Estas en el tema de Error en el beginTransaction en el foro de PHP en Foros del Web. Buenos días, Tengo una aplicación Web en la que actualizo e inserto nuevas filas en una tabla de una base de datos. A la hora ...
  #1 (permalink)  
Antiguo 13/11/2012, 04:44
 
Fecha de Ingreso: octubre-2012
Ubicación: Pozuelo de Alarcón
Mensajes: 67
Antigüedad: 11 años, 6 meses
Puntos: 1
Error en el beginTransaction

Buenos días,

Tengo una aplicación Web en la que actualizo e inserto nuevas filas en una tabla de una base de datos.

A la hora de meter dichas filas hago un PDO::beginTransaction para conectar con la BBDD de forma segura.
El problema que nunca me había dado ya que siempre funcionaba bien es el siguiente.

Error!: There is already an active transaction

No sé comprobar cuantas transations están activas no como pararlas para poder realizar la que yo quiero. He leído que se meten en una cola de espera, pero tampoco se acceder a ella. Nadie tiene abierta la BBDD ni ningún fichero que pueda acceder a ella. Por lo tanto llevo 3 días sin poder actualizar la BBDD.

Por favor alguien sabe como puedo solucionar ese error?

Les dejo el código de la función que realiza ese beginTransaction.

Código PHP:
Ver original
  1. public function insert($table, $fields, $rows)
  2.         {
  3.  
  4.             if (!isset($table) || (isset($fields) && !is_array($fields)) || !is_array($rows))
  5.             {
  6.                 die('Error in Db insert');
  7.             }
  8.             if (!is_array(current($rows)))
  9.             {
  10.                 $rows = array($rows);
  11.             }
  12.  
  13.             $query = 'INSERT INTO '.$table;
  14.             if (isset($fields))                        
  15.             {
  16.                 $query .= ' ('.implode(', ',$fields).')';
  17.             }
  18.             $query .= ' VALUES ';
  19.             $num_rows = count($rows);
  20.             $num_fields = count($fields);
  21.             $query .= '('.str_repeat('?,', $num_fields-1).'?)';
  22.  
  23.             try
  24.             {
  25.                 //print_r($query);
  26.                 $this->dbh->beginTransaction();
  27.                 //echo 'Hola';
  28.                 $result = $this->dbh->prepare($query);
  29.                 for ($i=0; $i<$num_rows; $i++)
  30.                 {
  31.                     $res = $result->execute(array_values($rows[$i]));
  32.                     if(!$res)
  33.                     {
  34.                         //echo 'INSERTION ERROR <br>'; 
  35.                         return FALSE;
  36.                     }
  37.                 }
  38.                 return $this->dbh->commit();
  39.             }
  40.             catch (PDOException $e)
  41.             {
  42.                 $this->fatal_error($e->getMessage());
  43.             }
  44.         }


Muchas gracias,

Un saludo

Última edición por taboacar; 13/11/2012 a las 06:09
  #2 (permalink)  
Antiguo 16/11/2012, 03:00
 
Fecha de Ingreso: octubre-2012
Ubicación: Pozuelo de Alarcón
Mensajes: 67
Antigüedad: 11 años, 6 meses
Puntos: 1
Respuesta: Error en el beginTransaction

[SOLUCIONADO]
No había ningún error en el código, era un error en la base de datos en la que se había quedado unas casillas en blanco al hacer la carga de los nuevos paquetes.

Un saludo

Etiquetas: tabla
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 08:24.