程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> php簡單備份與還原MySql的方法

php簡單備份與還原MySql的方法

編輯:PHP綜合

本文實例講述了php簡單備份與還原MySql的方法。分享給大家供大家參考,具體如下:

一、備份:

<?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:http://wyg517.blog.163.com
-->
<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 ($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基於pdo操作數據庫技巧總結》、《PHP+MongoDB數據庫操作技巧大全》、《php面向對象程序設計入門教程》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》

希望本文所述對大家PHP程序設計有所幫助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved