Foros del Web » Programando para Internet » PHP »

Problema codigo PHP backup de base de datos

Estas en el tema de Problema codigo PHP backup de base de datos en el foro de PHP en Foros del Web. Buen dia usuarios de foros del web veran necesito ayuda en un codigo php que poseeo que hace un backup de mi base de datos ...
  #1 (permalink)  
Antiguo 21/04/2016, 08:11
 
Fecha de Ingreso: agosto-2015
Ubicación: El Salvador
Mensajes: 17
Antigüedad: 9 años, 4 meses
Puntos: 0
Exclamación Problema codigo PHP backup de base de datos

Buen dia usuarios de foros del web veran necesito ayuda en un codigo php que poseeo que hace un backup de mi base de datos mysql,el codigo funciona perfectamente pero el detalle es que me crea el archivo .sql en la carpeta donde esta alojado el archivo php y lo que yo quiero es que brinde la posibilidad de guardarlo en el escritorio o en algun lugar donde yo quiera
el codigo es el siguiente:
Código PHP:
set_time_limit(0);
 
define('DB_NAME', 'db_sicopa_desa');
define('DB_HOST', 'localhost');
define('DB_USER', 'root');
define('DB_PASS', 'root');
 
 
function setQuery($setSelectQueryStr, $fetchType = NULL){
    $arr = array();
 
    try{
        $db = new PDO('mysql:host=' . DB_HOST . ';dbname=' . DB_NAME, DB_USER, DB_PASS);
        $db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
 
        $pdoQuery = $db->query($setSelectQueryStr);
        $fetchType = empty($fetchType) ? PDO::FETCH_ASSOC : $fetchType;
        $arr = ($pdoQuery->rowCount() > 0) ? $pdoQuery->fetchAll($fetchType) : array();
 
    }catch(PDOException $e){
        echo $e->getMessage();
        exit;
    }
 
    return $arr;
}
 
 
 
 
define('NL', PHP_EOL);
 
$drop = true; 
$tables = array(); 
$extra = array();
$constraints = array();
 
$f = fopen(DB_NAME . '.sql', 'w');
 
$query = setQuery('SHOW TABLES FROM `' . DB_NAME . '`', PDO::FETCH_NUM);
foreach($query as $row){
    $tables[] = $row[0];
}
 
$extra['dumpVersion'] = "1.0";
$extra['dtTm'] = date("Y-m-d H:i:s");
$extra['phpVersion'] = phpversion();
$extra['dbName'] = DB_NAME;
 
$t = array();
foreach($tables as $k => $v){
    $t[] = "[$k] => $v;";
}
$extra['tables'] = implode(NL . '--           ', $t);
 
$text = <<<HEADERTEXT
-- dumpFDW  
-- version {$extra['dumpVersion']}
-- http://www.forosdelweb.com/miembros/abimaelrc/
--  
-- Host: {$_SERVER['HTTP_HOST']}
-- Generation Time: {$extra['dtTm']}
-- PHP Version: {$extra['phpVersion']} 
-- Database: '{$extra['dbName']}' 
-- Tables: {$extra['tables']} 
HEADERTEXT;
 
fwrite($f, $text);
 
foreach ($tables as $table){
    fwrite($f, NL . NL .($drop ? "DROP TABLE IF EXISTS `$table`;" : "-- No especificado.") . NL);
 
    $query = setQuery("SHOW CREATE TABLE `$table`", PDO::FETCH_NUM);
    foreach($query as $row){
        $arr = explode("\n", $row[1]);
        $tmpArr = array();
        foreach($arr as $key => $value){
            if(stripos($value, "CONSTRAINT") !== false){
                $tmpArr[] = '  ADD ' . trim($value);
                if(array_key_exists($key - 1, $arr)){
                    $arr[$key - 1] = str_replace(',','',$arr[$key - 1]);
                }
                unset($arr[$key]);
            }
        }
        if(!empty($tmpArr)){
            $constraints[] = 'ALTER TABLE ' . $row[0] . NL . implode(NL, $tmpArr) . ';';
        }
        fwrite($f, implode(NL, $arr) . ';' . NL . NL);
    }
 
 
    $query = setQuery("SELECT * FROM `$table`");
 
    $n = 0;
    $nR = count($query) - 1;
    foreach($query as $qry){
        $columnas = array_keys($qry);
        $values = array();
        $keys = array();
 
        foreach($columnas as $columna){
            $keys[] = "`".$columna."`";
            if( is_numeric($qry[$columna]) || is_null($qry[$columna]) ){
                $values[] = $qry[$columna];
            } else{
                $values[] = "'" . str_replace(array("'", NL), array("''", '\r\n'), addcslashes($qry[$columna], '\\')) . "'";
            }
        }
 
        /* $sC = special Char, saber cual cáracter especial colocar al final del código */
        $sC = ($n%2000 == 1999 || $n == $nR ? ";" : ",");
 
        if($n%2000 == 0){
            fwrite($f, "INSERT INTO `$table`(".implode(", ", $keys).") VALUES " . NL . "(" . implode(", ", $values) . ")" . $sC . NL);
        }else{
            fwrite($f, "(" . implode(", ", $values) . ")" . $sC . NL);
        }
        $n++;
    }
}
 
if(!empty($constraints)){
    fwrite($f, NL . NL . implode(NL . NL, $constraints));
}
 
fclose($f); 

?> <script type="text/javascript">alertify.success('Copia de Base de datos generada');</script> <?php
espero me puedan ayudar feliz dia!
  #2 (permalink)  
Antiguo 21/04/2016, 08:24
Avatar de petit89  
Fecha de Ingreso: marzo-2011
Mensajes: 1.139
Antigüedad: 13 años, 9 meses
Puntos: 171
Respuesta: Problema codigo PHP backup de base de datos

pues para mi que tendria que ser asi...

Código PHP:
Ver original
  1. $f = fopen('ruta' . DB_NAME . '.sql', 'w');
__________________
█ WebHosting / Reseller a bajo costo | Uptime Garantizado | Soporte en Español e Ingles
¿Te sirvió la respuesta? Deja un +1 (Triangulo negro al lado derecho)

Etiquetas: php+bd
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 10:19.