php备份还原数据库 php文件备份

php,mysql数据库备份和还原的最理想方式 , 类似phpadmin的代码一、备份数据库并下载到本地【db_backup.php】
复制代码 代码如下:
?php
// 设置SQL文件保存文件名
$filename=date("Y-m-d_H-i-s")."-".$cfg_dbname.".sql";
// 所保存的文件名
header("Content-disposition:filename=".$filename);
header("Content-type:application/octetstream");
header("Pragma:no-cache");
header("Expires:0");
// 获取当前页面文件路径,SQL文件就导出到此文件夹内
$tmpFile = (dirname(__FILE__))."\\".$filename;
// 用MySQLDump命令导出数据库
exec("mysqldump -u$cfg_dbuser -p$cfg_dbpwd --default-character-set=utf8 $cfg_dbname".$tmpFile);
$file = fopen($tmpFile, "r"); // 打开文件
echo fread($file,filesize($tmpFile));
fclose($file);
exit;
?
二、还原数据库【db_restore.php】
复制代码 代码如下:
form id="form1" name="form1" method="post" action=""
【数据库SQL文件】:input id="sqlFile" name="sqlFile" type="file" /
input id="submit" name="submit" type="submit" value="https://www.04ip.com/post/还原" /
/form
?php
// 我的数据库信息都存放到config.php文件中 , 所以加载此文件,如果php备份还原数据库你的不是存放到该文件中,注释此行即可php备份还原数据库;
require_once((dirname(__FILE__).'/../../include/config.php'));
if ( isset ( $_POST['sqlFile'] ) )
{
$file_name = $_POST['sqlFile']; //要导入的SQL文件名
$dbhost = $cfg_dbhost; //数据库主机名
$dbuser = $cfg_dbuser; //数据库用户名
$dbpass = $cfg_dbpwd; //数据库密码
$dbname = $cfg_dbname; //数据库名
set_time_limit(0); //设置超时时间为0 , 表示一直执行 。当php在safe mode模式下无效 , 此时可能会导致导入超时,此时需要分段导入
$fp = @fopen($file_name, "r") or die("不能打开SQL文件 $file_name");//打开文件
mysql_connect($dbhost, $dbuser, $dbpass) or die("不能连接数据库 $dbhost");//连接数据库
mysql_select_db($dbname) or die ("不能打开数据库 $dbname");//打开数据库
echo "p正在清空数据库,请稍等....br";
$result = mysql_query("SHOW tables");
while ($currow=mysql_fetch_array($result))
{
mysql_query("drop TABLE IF EXISTS $currow[0]");
echo "清空数据表【".$currow[0]."】成功php备份还原数据库!br";
}
echo "br恭喜你清理MYSQL成功br";
echo "正在执行导入数据库操作br";
// 导入数据库的MySQL命令
exec("mysql -u$cfg_dbuser -p$cfg_dbpwd $cfg_dbname".$file_name);
echo "br导入完成!";
mysql_close();
}
?
如何使用Discuz,后台备份和恢复Discuz,站点数据库Discuz!为方便用户备份和恢复数据库php备份还原数据库,已在后台内置了此功能php备份还原数据库,易于站长操作 。今天在这分享一下Discuz!
x2.5论坛后台数据库的备份和恢复方法,以及备份数据库和恢复数据库要注意的一些细节问题 。
一、利用Discuz!后台备份数据库
1、为备份数据完整无误 , 备份数据前请站长先关闭站点;
2、利用站长权限登录后台——》站长——》数据库——》备份,有两个基本的数据备份类型:“Discuz!

UCenter
数据”

“自定义备份”;
1)、选择“Discuz!

UCenter
数据”,会备份你Discuz!数据库的所有数据表文件;(包括插件等生成的数据表)
2)、选择“自定义备份”,按照要求勾选你要备份的数据表即可 。
【php备份还原数据库 php文件备份】3、“提交”旁边有一个“更多选项”,用户可以根据自己的需求来设置一下更多选项 , 不是很懂的用户可以不必点开更多选项设置,保持Discuz!设置的默认值就可以了;下面分析一下更多选项的技巧提示:

推荐阅读