Foros del Web » Programando para Internet » PHP »

script php para hacer copia seguridad DB

Estas en el tema de script php para hacer copia seguridad DB en el foro de PHP en Foros del Web. Tengo que hacer una copia de seguridad, pero sin usar dump u otro comando. Es decir programarlo todo con php. Tengo esto, pero no se ...
  #1 (permalink)  
Antiguo 02/04/2011, 14:02
 
Fecha de Ingreso: septiembre-2010
Mensajes: 72
Antigüedad: 13 años, 7 meses
Puntos: 0
script php para hacer copia seguridad DB

Tengo que hacer una copia de seguridad, pero sin usar dump u otro comando. Es decir programarlo todo con php.
Tengo esto, pero no se como seguir:
<?php
//*****************************************
//Aparte de las funciones mysql_connect, mysql_db_query, etc, se usarán mysql_list_tables,
// mysql_field_name, mysql_field_type. Se volcarán los datos de las tablas en un fichero,
// que se comprimirá y se enviará mediante el protocolo ftp a ftp....... .com.
//El fichero contendrá sentencias SQL como: DROP TABLE, CREATE TABLE, INSERT INTO.
//De tal forma, que si se destruye la base de datos se pueda restaurar todo sus tablas por medio
// de la ejecución SQL de dicho fichero.
//*********************************************
//$conexion = mysql_connect($host, $usurio, $passwd)
//$link = mysql_connect('dbhost', 'username', 'password');
$link= mysql_connect('....','.....','...');
$db_list = mysql_list_dbs($link);

while ($row = mysql_fetch_object($db_list)) {
echo "drop database if exists ".$row->Database.";";
echo "<br>";
echo "create database ".$row->Database.";";
echo "<br>";

// Se busca las tablas en la base de datos
$sql = "SHOW TABLES FROM $row->Database";
$result = mysql_query($sql,$link);
if (!$result) {
echo "DB Error, no se pudo listar las tablas\n";
echo 'MySQL Error: ' . mysql_error();
exit;
}
while ($filas = mysql_fetch_array($result)) {
echo "<font color= 'blue'>TABLA: </font>". $filas[0]. "<br>";

$db_selected = mysql_select_db($row->Database, $link);
$sql1= "select * from $filas[0]";
//echo "$sql1" ;
$res = mysql_query($sql1, $link);
$campos = mysql_num_fields($res);
$rows = mysql_num_rows($res);
$table = mysql_field_table($res, 0);

echo " La tabla '" . $tabla . "' tiene " . $campos . " campos y " . $rows . registros."<br>";
echo "<font color= 'red'> LA TABLA TINEN LOS SIGUIENTES CAMPOS:</font>.<br>";
for ($i=0; $i < $campos; $i++) {
$TIPO = mysql_field_type($res, $i);
$nombre = mysql_field_name($res, $i);
$TAMANO = mysql_field_len($res, $i);
$CARACTER = mysql_field_flags($res, $i);
echo $TIPO . " " . $nombre . " " . $TAMANO . " " . $CARACTER . "<br>";

$table = mysql_field_table($res, $i);
// echo "$table";
}
}
}
?>
gracias
  #2 (permalink)  
Antiguo 02/04/2011, 17:54
Avatar de maycolalvarez
Colaborador
 
Fecha de Ingreso: julio-2008
Ubicación: Caracas
Mensajes: 12.120
Antigüedad: 15 años, 9 meses
Puntos: 1532
Respuesta: script php para hacer copia seguridad DB

¿como que no sabes como seguir?, ¿al menos sabes lo que hace el código anterior?, siempre es bueno no reinventar la rueda, pero al menos debe de saberse como funciona, aunque solo se conozca su funcionamiento básico.

¿has probado el codigo, o no, te funciona, que necesitas, como lo puedes obtener, etc?
__________________
¡Por favor!: usa el highlight para mostrar código
El que busca, encuentra...
  #3 (permalink)  
Antiguo 03/04/2011, 02:32
 
Fecha de Ingreso: septiembre-2010
Mensajes: 72
Antigüedad: 13 años, 7 meses
Puntos: 0
Respuesta: script php para hacer copia seguridad DB

Si funciona, y veo los nº campos, nombre tablas, etc..
  #4 (permalink)  
Antiguo 06/04/2011, 10:01
 
Fecha de Ingreso: septiembre-2010
Mensajes: 72
Antigüedad: 13 años, 7 meses
Puntos: 0
Respuesta: script php para hacer copia seguridad DB

Bien ya está listo y todo funciona.
La ayuda que necesito es para que en el fichero en lugar de not_null salga NOT NULL.
Y si se puede quitar el /n al comienzo de crear las tablas

(lo pongo en negritas para indicarlo)

Ejemplo de lo sale en el fichero

\nCREATE TABLE enrique2
(id int not_null primary_key auto_increment;nombre varchar(30) not_null;
clave varchar(30) not_null;

Etiquetas: copia, seguridad
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 07:22.