Con el siguiente script he conseguido que me genere el txt aparentemente correcto. Pero me imprime algo que no entiendo
Código PHP:
Ver originalfunction copiaBD()
{
$nombre = "copia_bd.txt";
/* Determina si la tabla será vaciada (si existe) cuando restauremos la tabla. */
$drop = false;
/*
* Array que contiene las tablas de la base de datos que seran resguardadas.
* Puede especificarse un valor false para resguardar todas las tablas
* de la base de datos especificada en $bd.
*
* Ejs.:
* $tablas = false;
* o
* $tablas = array("tabla1", "tabla2", "tablaetc");
*
*/
$tablas = false;
/*
* Tipo de compresion.
* Puede ser "gz", "bz2", o false (sin comprimir)
*/
$compresion = false;
/* Conexion y eso*/
$conexion = conectar
() or
die("No se conectar con el servidor MySQL: ".mysql_error());
$bd = "basededatos";
/* Se busca las tablas en la base de datos */
$consulta = "SHOW TABLES FROM $bd;";
$tablas[] = $fila[0];
}
}
/* Se crea la cabecera del archivo */
$info['dumpversion'] = "1.1b";
$info['fecha'] = date("d-m-Y"); $info['hora'] = date("h:m:s A"); $info['tablas'] = implode("; ", $matches[1]); $dump = <<<EOT
# +===================================================================
# | COPIA DE SEGURIDAD DE LA BASE DE DATOS DE INTÉRPRETES
# |
# | Generado el {$info['fecha']} a las {$info['hora']} por el usurio '$usurio'
# | Base de datos: '$bd'
# | Tablas: {$info['tablas']}
# |
# +-------------------------------------------------------------------
EOT;
foreach ($tablas as $tabla) {
$drop_table_query = "";
$create_table_query = "";
$insert_into_query = "";
/* Se halla el query que será capaz vaciar la tabla. */
if ($drop) {
$drop_table_query = "DROP TABLE IF EXISTS `$tabla`;";
} else {
$drop_table_query = "# No especificado.";
}
/* Se halla el query que será capaz de recrear la estructura de la tabla. */
$create_table_query = "";
$consulta = "SHOW CREATE TABLE $tabla;";
$create_table_query = $fila[1].";";
}
/* Se halla el query que será capaz de insertar los datos. */
$insert_into_query = "";
$consulta = "SELECT * FROM $tabla;";
foreach ($columnas as $columna) {
if ( gettype($fila[$columna]) == "NULL" ) { $values[] = "NULL";
} else {
}
}
$insert_into_query .= "INSERT INTO `$tabla` VALUES (".implode(", ", $values).");\n"; }
$dump .= <<<EOT
# | Vaciado de tabla '$tabla'
# +------------------------------------->
$drop_table_query
# | Estructura de la tabla '$tabla'
# +------------------------------------->
$create_table_query
# | Carga de datos de la tabla '$tabla'
# +------------------------------------->
$insert_into_query
EOT;
}
/* Envio */
header("Content-Transfer-Encoding: binary"); switch ($compresion) {
case "gz":
header("Content-Disposition: attachment; filename=$nombre.gz"); header("Content-type: application/x-gzip"); break;
case "bz2":
header("Content-Disposition: attachment; filename=$nombre.bz2"); header("Content-type: application/x-bzip2"); break;
default:
header("Content-Disposition: attachment; filename=$nombre"); header("Content-type: application/force-download"); echo $dump;
}
} else {
echo "<b>ATENCION: Probablemente ha ocurrido un error</b><br />\n<pre>\n$dump\n</pre>";
}
}
Me imprime correctamente la copia de seguridad. Pero al final de este código también me imprime el javascript con el que consulto a la base de datos para los combos anidados.
Alguien puede decirme dónde está la orden para que me haga eso??
Gracias!!