备份mysql数据库并下载为文件

时间:2010-09-20 11:38:42

标签: php mysql

如何备份mysql数据库并使用PHP代码将其下载为.sql文件

6 个答案:

答案 0 :(得分:5)

一个非常简单的解决方案就像(第一个例子): http://www.php-mysql-tutorial.com/wikis/mysql-tutorials/using-php-to-backup-mysql-databases.aspx

当然,这只会进行表格的数据转储。

您可以使用此代码:

http://snipplr.com/view/173/mysql-dump/

此代码的作用实际上是获取表的描述(即其结构),创建所有表并推送数据。就像任何其他工具一样。

然后只需将其从字符串保存到文件(例如file_put_contents()或类似的东西,具体取决于您的偏好和需要)

答案 1 :(得分:3)

mysqldump -u username -p password database > file

或者,phpMyAdmin也可以使用“导出”工具执行此操作。

答案 2 :(得分:1)

使用phpmyadmin

编辑:

您可以使用shell_exec执行此命令

mysqldump -u username -p password database>档案

这将生成转储文件,然后将用户重定向到此生成的文件。

答案 3 :(得分:0)

你有phpmyadmin吗?如果是这样,您可以通过单击顶部的“导出”(在选定的表/数据库上)从那里导出它。

答案 4 :(得分:0)

我知道它有点晚了,但希望别人能找到它。

//php file - html code:
    require_once 'connect.php'; //holds database variables with connect details
    require_once 'Admin_DatabaseFiles_Backup.php'; //Include the admin logout script

<form action="" method="post" class="form form">
    <!--<input type="hidden" name="backup" value="1" />-->
    <div class="float_left w200">
        <p>
            <label class="title">Backup database</label>
            <span class="left">
              <input type="checkbox" name="db" value="1" checked="checked"/>
            </span>
        </p>
        <p>
            <label class="title">Backup files</label>
            <span class="left">
                <input type="checkbox" name="files" value="1" checked="checked" />
            </span>
        </p>
    </div>
    <p class="float_left">
        <input type="submit" name="submit" value="Backup" class="button" />
    </p>
</form>

//php file Admin_DatabaseFiles_Backup.php:
<?php


if ($_POST['submit']=="Backup"){

    if ($_POST['db'] == "1"){

        $directory = "DatabaseFileBackups/";
        $dateAndTime = "".date('d-m-Y-H-i-s');
        $fileName = "".$dbname.$dateAndTime.".sql";
        $backupFile = "mysqldump --user=$dbuser --password='$dbpass' --host=$dbhost $dbname > ".$directory.$fileName;

        exec($backupFile,$output);

        if($output == ''){ 
            echo = '<br />Failed To Backup Database!';
        }else{
            echo = '<br />Database Backup Was Successful!';
        }
    }

    if ($_POST['files'] == "1"){

            echo 'Seleceted files';

    }
}


?>

答案 5 :(得分:-2)

如果您有phpMyAdmin,可以在“导出”菜单中执行此操作。

如果您要查找命令行工具,请查看mysqldump