php备份、还原数据库的实例代码

发布时间:2019-09-28编辑:脚本学堂
分享下php实现mysql数据库的备份与还原的方法,在日常的php编程中经常用得到,有需要的朋友参考下吧。

例1,备份数据库
 

复制代码 代码示例:

<?php
$host="localhost"; 
$user="####";//数据库账号
$password="###";//数据库密码
$dbname="###";//数据库名称
//这里的账号、密码、名称都是从页面传过来的
if(!mysql_connect($host,$user,$password))  //连接mysql数据库
{
 echo '数据库连接失败,请核对后再试';
 exit;
}
if(!mysql_select_db($dbname))  //是否存在该数据库
{
 echo '不存在数据库:'.$dbname.',请核对后再试';
 exit;
}

//$mysql= "set charset utf8;rn"; 
$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'].";rn";
    $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);rn";
    }
}

$filename="../bak/".$_POST[b_name];  //存放路径,默认存放到项目最外层
$fp = fopen($filename,'w');
fputs($fp,$mysql);
fclose($fp);
?>

2,还原数据库
 

复制代码 代码示例:
<?php
$filename = $_POST[r_name];
$host="localhost"; //主机名
$user="root"; //MYSQL用户名
$password="1234"; //密码
$dbname="db_office"; //在此指定您要恢复的数据库名,不存在则必须先创建,请自已修改数据库名
$conns=mysql_connect($host,$user,$password);
mysql_select_db($dbname);
$result = mysql_query("show table status from $dbname",$conns);
while($data=mysql_fetch_array($result)) {
mysql_query("drop table $data[Name]");
}
$mysql_file="../bak/".$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(";rn", $sql_value);  //根据";rn"条件对数据库中分条执行
   $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
    { // www.jb200.com
     $sb+=1;
     $sb_command[$sb]=$a[$i];
    }
   }
   echo "<script>alert('操作完毕,共处理 $total 条命令,成功 $cg 条,失败 $sb 条');location='data_stock.php'</script>";
   //显示错误信息
   if ($sb>0)
   {
    echo "<hr><br><br>失败命令如下:<br>";
    for ($ii=1;$ii<=$sb;$ii++)
    {
     echo "<p><b>第 ".$ii." 条命令(内容如下):</b><br>".$sb_command[$ii]."</p><br>";
    }
   }   //--
  }else{
   echo "MySQL备份文件不存在,请检查文件路径是否正确!";
  }
 }
?>

您可能感兴趣的文章:
php数据库备份类 分享一个不错的php数据库备份类
php完整备份数据库与备份数据库中指定表的类
php Mysql数据库备份类及调用方法
php实现mysql的备份与还原实例代码
php实现MYSQL的备份与还原
php数据备份:单表备份 整表备份 导入数据库