php简单备份与还原MySql的方法具体如下:
创新互联主营尼河口网站建设的网络公司,主营网站建设方案,成都APP应用开发,尼河口h5重庆小程序开发搭建,尼河口网站营销推广欢迎尼河口等地区企业咨询
一、备份:
?php
header ( "content-Type: text/html; charset=utf-8" );
//备份数据库
$host="localhost";
$user="root";//数据库账号
$password="123456";//数据库密码
$dbname="test";//数据库名称
//这里的账号、密码、名称都是从页面传过来的
if(!mysql_connect($host,$user,$password)) //连接mysql数据库
{
echo '数据库连接失败,请核对后再试';
exit;
}
if(!mysql_select_db($dbname)) //是否存在该数据库
{
echo '不存在数据库:'.$dbname.',请核对后再试';
exit;
}
mysql_query("set names 'utf8'");
$mysql= "set charset utf8;\r\n";
$q1=mysql_query("show tables");
while($t=mysql_fetch_array($q1)){
$table=$t[0];
$q2=mysql_query("show create table `$table`");
$sql=mysql_fetch_array($q2);
$mysql.=$sql['Create Table'].";\r\n";
$q3=mysql_query("select * from `$table`");
while($data=mysql_fetch_assoc($q3)){
$keys=array_keys($data);
$keys=array_map('addslashes',$keys);
$keys=join('`,`',$keys);
$keys="`".$keys."`";
$vals=array_values($data);
$vals=array_map('addslashes',$vals);
$vals=join("','",$vals);
$vals="'".$vals."'";
$mysql.="insert into `$table`($keys) values($vals);\r\n";
}
}
$filename="data/".$dbname.date('Ymjgi').".sql"; //存放路径,默认存放到项目最外层
$fp = fopen($filename,'w');
fputs($fp,$mysql);
fclose($fp);
echo "数据备份成功";
?
二、还原
!--
author:果冻
qq:52091199
blog:
--
meta http-equiv="Content-Type" content="text/html; charset=utf-8" /
?php
$filename = "test20101216923.sql";
$host="localhost"; //主机名
$user="root"; //MYSQL用户名
$password="123456"; //密码
$dbname="test"; //在此指定您要恢复的数据库名,不存在则必须先创建,请自已修改数据库名
mysql_connect($host,$user,$password);
mysql_select_db($dbname);
$mysql_file="data/".$filename; //指定要恢复的MySQL备份文件路径,请自已修改此路径
restore($mysql_file); //执行MySQL恢复命令
function restore($fname)
{
if (file_exists($fname)) {
$sql_value="";
$cg=0;
$sb=0;
$sqls=file($fname);
foreach($sqls as $sql)
{
$sql_value.=$sql;
}
$a=explode(";\r\n", $sql_value); //根据";\r\n"条件对数据库中分条执行
$total=count($a)-1;
mysql_query("set names 'utf8'");
for ($i=0;$i$total;$i++)
{
mysql_query("set names 'utf8'");
//执行命令
if(mysql_query($a[$i]))
{
$cg+=1;
}
else
{
$sb+=1;
$sb_command[$sb]=$a[$i];
}
}
echo "操作完毕,共处理 $total 条命令,成功 $cg 条,失败 $sb 条";
//显示错误信息
if ($sb0)
{
echo "hrbrbr失败命令如下:br";
for ($ii=1;$ii=$sb;$ii++)
{
echo "pb第 ".$ii." 条命令(内容如下):/bbr".$sb_command[$ii]."/pbr";
}
} //-----------------------------------------------------------
}else{
echo "MySQL备份文件不存在,请检查文件路径是否正确!";
}
}
?
1,恢复前备份。2,有之前的备份才可以恢复。3,下载数据库管理工具,sqlyun,navcat,等可进行导入导出。4.注意恢复期间对前台影响。(最好关闭前台访问)5.做好出问题时的应对准备
可以,利用 MySql日志文件 恢复数据 。这个恢复是有前提的,就是你至少得有一个从日志记录开始后的数据库备份,通过日志恢复数据库实际上只是一个对以前操作的回放过程而已。
1、用FTP登陆到【caches/bakup/default】文件夹,把这个文件夹整个复制下来吧,简单点操作。
2、把复制的文件【default】复制一份作为备份,省的不能挽回。
3、找到你造成让你后悔手贱那一刻的时间,并且把那个时间的文件全部圈出来,都要改的!
4、把其中里面的【capable.sql】改名为【phpcmstables_20130407_3755_1.sql】就是这个数字格式。当然数字可以换!
5、把你从新命名的文件回传到你的主机【caches/bakup/default】文件夹下。
6、去你的后台-扩展-数据库工具-数据库导入,你发现你刚才命名的文件【phpcmstables_20130407_3755_1.sql】出现了,请点击后面的【数据库恢复】,谢天谢地,主表回来了。你可以点击下【管理内容】,现在各栏目算是回来了。
7、紧接着,请把那个灾难时间产生的文件依次序命名为【phpcmstables_20130407_3755_1.sql】格式。
8、先命名download.sql 再命名download_data.sql (就是先恢复没有data的),如果你将 download.sql命名为phpcmstables_20130407_3756_1.sql,那么最好将download_data.sql 命名为phpcmstables_20130407_3756_2.sql.
9、将重命名的文件上传到你的主机的【caches/bakup/default】文件夹下。
10、重复6的步骤,按照你命名的顺序,点击【1】,数据库会自动把连号的【2】也恢复的!
11、当你的文件依次恢复后,你能看到效果的。
12、可能你在恢复过程有报错,但是还是能用的,请继续!