如何备份mysql数据库并使用PHP代码将其下载为.sql文件
答案 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)
答案 3 :(得分:0)
答案 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。