mysqldump 命令不执行只是保存在文件中
mysqldump command is not executed just it is saved on a file
我正在编写一个 php 备份数据库的脚本,我的想法是使用我的sqldump 命令,然后下载一个 sql 文件和结果,不幸的是输出mysqldump 不保存在文件中,只保存源代码。这是代码:
$archivo = 'bkbiblioteca_' . date("d-m-Y_H:i:s") . '.sql';
$comando = "mysqldump --add-drop-table --host=$servidor --user=$usuario --password=$clave $base > $archivo";
try{
$archivo_manejador = fopen($archivo, 'w+');
fwrite($archivo_manejador, $comando);
fclose($archivo_manejador);
header('Content-Description: File Transfer');
header('Content-Type: application/octet-stream');
header('Content-Disposition: attachment; filename=' . basename($archivo));
header('Content-Transfer-Encoding: binary');
header('Expires: 0');
header('Cache-Control: must-revalidate');
header('Pragma: public');
header('Content-Length: ' . filesize($archivo));
ob_clean();
flush();
readfile($archivo);
unlink($archivo);
}catch(\Exception $e){
echo 'error en el proceso de bk' . $e->getMessage(); //TODO: favor incluir en la bitacora global del sistema
}//fin de catch
现在我正在获取包含以下行的文件:
mysqldump --add-drop-table --host=$servidor --user=$usuario --password=$clave $base > $archivo
我试过这个命令:
system("$comando");
但是不行,所以我想不通如何执行mysqldump命令并在文件中获取结果而不是获取源代码行。
提前致谢
尝试:
system($comando);
或者也许:
exec($comando);
删除此行解决问题:
$archivo_manejador = fopen($archivo, 'w+');
现在我得到了需要的输出。感谢 Francois Huppé 的评论。
使用 mysqldump
的 --result-file
选项创建转储文件,然后您可以将其发送到浏览器进行下载。完整的命令是(根据需要插入您的文件名):
exec('mysqldump --user=backup --password="yourpasswordhere#" --routines --insert-ignore --complete-insert --force --result-file=name_of_your_dump_file_here.sql --databases ' . $yourdatabasename);
我正在编写一个 php 备份数据库的脚本,我的想法是使用我的sqldump 命令,然后下载一个 sql 文件和结果,不幸的是输出mysqldump 不保存在文件中,只保存源代码。这是代码:
$archivo = 'bkbiblioteca_' . date("d-m-Y_H:i:s") . '.sql';
$comando = "mysqldump --add-drop-table --host=$servidor --user=$usuario --password=$clave $base > $archivo";
try{
$archivo_manejador = fopen($archivo, 'w+');
fwrite($archivo_manejador, $comando);
fclose($archivo_manejador);
header('Content-Description: File Transfer');
header('Content-Type: application/octet-stream');
header('Content-Disposition: attachment; filename=' . basename($archivo));
header('Content-Transfer-Encoding: binary');
header('Expires: 0');
header('Cache-Control: must-revalidate');
header('Pragma: public');
header('Content-Length: ' . filesize($archivo));
ob_clean();
flush();
readfile($archivo);
unlink($archivo);
}catch(\Exception $e){
echo 'error en el proceso de bk' . $e->getMessage(); //TODO: favor incluir en la bitacora global del sistema
}//fin de catch
现在我正在获取包含以下行的文件: mysqldump --add-drop-table --host=$servidor --user=$usuario --password=$clave $base > $archivo
我试过这个命令:
system("$comando");
但是不行,所以我想不通如何执行mysqldump命令并在文件中获取结果而不是获取源代码行。
提前致谢
尝试:
system($comando);
或者也许:
exec($comando);
删除此行解决问题:
$archivo_manejador = fopen($archivo, 'w+');
现在我得到了需要的输出。感谢 Francois Huppé 的评论。
使用 mysqldump
的 --result-file
选项创建转储文件,然后您可以将其发送到浏览器进行下载。完整的命令是(根据需要插入您的文件名):
exec('mysqldump --user=backup --password="yourpasswordhere#" --routines --insert-ignore --complete-insert --force --result-file=name_of_your_dump_file_here.sql --databases ' . $yourdatabasename);