为了账号安全,请及时绑定邮箱和手机立即绑定

mysqldump 命令不执行,只是保存在文件中

mysqldump 命令不执行,只是保存在文件中

PHP
慕尼黑的夜晚无繁华 2021-11-05 13:19:14
我正在编写一个用于备份数据库的 php 脚本,想法是使用 mysqldump 命令,然后下载一个带有结果的 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命令并在文件中获取结果而不是获取源代码行。提前致谢
查看完整描述

3 回答

?
qq_遁去的一_1

TA贡献1725条经验 获得超7个赞

使用--result-file选项mysqldump创建转储文件,然后您可以将其发送到浏览器进行下载。完整的命令是(根据需要插入您的文件名):

exec('mysqldump --user=backup --password="yourpasswordhere#" --routines --insert-ignore --complete-insert --force --result-file=name_of_your_dump_file_here.sql --databases ' . $yourdatabasename);



查看完整回答
反对 回复 2021-11-05
?
紫衣仙女

TA贡献1839条经验 获得超15个赞

删除这一行可以解决问题:

$archivo_manejador = fopen($archivo, 'w+');

现在我得到了所需的输出。感谢 Francois Huppé 的评论。


查看完整回答
反对 回复 2021-11-05
?
HUX布斯

TA贡献1876条经验 获得超6个赞

尝试:

system($comando);

或者可能:

exec($comando);


查看完整回答
反对 回复 2021-11-05
  • 3 回答
  • 0 关注
  • 204 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信