如何在PHP中备份MySQL数据库?
我对通过PHP备份MySQL数据库的工作原理没有基本的了解。我遵循了一个教程,但它没有帮助我理解。
有人可以解释如何从PHP创建MySQL备份吗?
我对通过PHP备份MySQL数据库的工作原理没有基本的了解。我遵循了一个教程,但它没有帮助我理解。
有人可以解释如何从PHP创建MySQL备份吗?
虽然您可以从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 OUTFILE
LOAD DATA INFILE
这很简单,您正在使用一个命令编写SQL文件,并在需要还原时加载/执行它。
您可以在此处找到选择到outfile的文档(只需在页面中搜索outfile)。“加载数据文件”实质上与此相反。有关文档,请参阅此处。
基于tazo todua提供的良好解决方案,我进行了一些更改,因为已经弃用并且不支持新的php版本。我改用并提高了将值插入数据库的性能:mysql_connect
mysqli_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;
}
}