如何在PHP中备份MySQL数据库?

2022-08-30 11:28:33

我对通过PHP备份MySQL数据库的工作原理没有基本的了解。我遵循了一个教程,但它没有帮助我理解。

有人可以解释如何从PHP创建MySQL备份吗?


答案 1

虽然您可以从PHP执行备份命令,但它们实际上与PHP没有任何关系。这一切都与MySQL有关。

我建议使用mysqldump实用程序来备份数据库。文档可以在这里找到:http://dev.mysql.com/doc/refman/5.1/en/mysqldump.html

mysqldump的基本用法是

mysqldump -u user_name -p name-of-database >file_to_write_to.sql

然后,您可以使用以下命令还原备份

mysql -u user_name -p <file_to_read_from.sql

您是否有权访问 cron?我建议制作一个PHP脚本,将mysqldump作为cron作业运行。那将是这样的

<?php

$filename='database_backup_'.date('G_a_m_d_y').'.sql';

$result=exec('mysqldump database_name --password=your_pass --user=root --single-transaction >/var/backups/'.$filename,$output);

if(empty($output)){/* no output is good */}
else {/* we have something to log the output here*/}

如果 mysqldump 不可用,本文将使用 and 命令介绍另一种方法。与 PHP 的唯一连接是使用 PHP 连接到数据库并执行 SQL 命令。您也可以从命令行MySQL程序(MySQL监视器)执行此操作。SELECT INTO OUTFILELOAD DATA INFILE

这很简单,您正在使用一个命令编写SQL文件,并在需要还原时加载/执行它。

您可以在此处找到选择到outfile的文档(只需在页面中搜索outfile)。“加载数据文件”实质上与此相反。有关文档,请参阅此处


答案 2

基于tazo todua提供的良好解决方案,我进行了一些更改,因为已经弃用并且不支持新的php版本。我改用并提高了将值插入数据库的性能:mysql_connectmysqli_connect

<?php

/**
* Updated: Mohammad M. AlBanna
* Website: MBanna.info
*/


//MySQL server and database
$dbhost = 'localhost';
$dbuser = 'my_user';
$dbpass = 'my_pwd';
$dbname = 'database_name';
$tables = '*';

//Call the core function
backup_tables($dbhost, $dbuser, $dbpass, $dbname, $tables);

//Core function
function backup_tables($host, $user, $pass, $dbname, $tables = '*') {
    $link = mysqli_connect($host,$user,$pass, $dbname);

    // Check connection
    if (mysqli_connect_errno())
    {
        echo "Failed to connect to MySQL: " . mysqli_connect_error();
        exit;
    }

    mysqli_query($link, "SET NAMES 'utf8'");

    //get all of the tables
    if($tables == '*')
    {
        $tables = array();
        $result = mysqli_query($link, 'SHOW TABLES');
        while($row = mysqli_fetch_row($result))
        {
            $tables[] = $row[0];
        }
    }
    else
    {
        $tables = is_array($tables) ? $tables : explode(',',$tables);
    }

    $return = '';
    //cycle through
    foreach($tables as $table)
    {
        $result = mysqli_query($link, 'SELECT * FROM '.$table);
        $num_fields = mysqli_num_fields($result);
        $num_rows = mysqli_num_rows($result);

        $return.= 'DROP TABLE IF EXISTS '.$table.';';
        $row2 = mysqli_fetch_row(mysqli_query($link, 'SHOW CREATE TABLE '.$table));
        $return.= "\n\n".$row2[1].";\n\n";
        $counter = 1;

        //Over tables
        for ($i = 0; $i < $num_fields; $i++) 
        {   //Over rows
            while($row = mysqli_fetch_row($result))
            {   
                if($counter == 1){
                    $return.= 'INSERT INTO '.$table.' VALUES(';
                } else{
                    $return.= '(';
                }

                //Over fields
                for($j=0; $j<$num_fields; $j++) 
                {
                    $row[$j] = addslashes($row[$j]);
                    $row[$j] = str_replace("\n","\\n",$row[$j]);
                    if (isset($row[$j])) { $return.= '"'.$row[$j].'"' ; } else { $return.= '""'; }
                    if ($j<($num_fields-1)) { $return.= ','; }
                }

                if($num_rows == $counter){
                    $return.= ");\n";
                } else{
                    $return.= "),\n";
                }
                ++$counter;
            }
        }
        $return.="\n\n\n";
    }

    //save file
    $fileName = 'db-backup-'.time().'-'.(md5(implode(',',$tables))).'.sql';
    $handle = fopen($fileName,'w+');
    fwrite($handle,$return);
    if(fclose($handle)){
        echo "Done, the file name is: ".$fileName;
        exit; 
    }
}

推荐