MySQL数据库中备份/恢复的两方法介绍

2016-01-29 14:51 7 1 收藏

MySQL数据库中备份/恢复的两方法介绍,MySQL数据库中备份/恢复的两方法介绍

【 tulaoshi.com - MySQL 】

下面介绍MySQL数据库备份/恢复的两种方法。

方法一:

<?php/* * 功能:数据备份/恢复文件简易方法 *   以日期为单位,一天一个备份文件,以当天最后备份为准 *   用提交表单的形式进行操作, *  其中$_POST["tbl_name"]为预备份表名称数组 *      $_POST["sqlfile"]为预恢复数据文件的名称 *  注意:该备份没有结构备份,只有数据备份 * *  备份文件格式: *  `表名称1`{{数据1}}`表名称2`{{数据2}}`表名称3`{{数据3}}... *  * 创建时间:2005-02-25 * E-mail: kingerq AT msn.com * 来源:http://blog.csdn.net/kingerq */include("../inc/globals.inc.php");//省略包函文件db_mysql.inc和MYSQL连接信息set_time_limit(0);$dbdir = "d:/site/dbbak/";//用绝对路径$txtname = array();if($_POST){ if(!is_writable($dbdir)) {  echo "对不起!指定的备份目录不可写!请修改权限";  exit; }  //op为一个隐形域,识别备份或者恢复 if($_POST["op"]){//备份数据  //生成每个表的临时备份文件  foreach($_POST["tbl_name"] as $tbl){   $txtname[] = $tbl.".txt";   $sql = "SELECT * FROM `$tbl` INTO OUTFILE '".$dbdir.end($txtname)."'";   $db-query($sql);  }   //将生成的临时备份文件合在一起  $outfile = date("Y-m-d").".sql";    if(file_exists($dbdir.$outfile)) @unlink($dbdir.$outfile);    $fpr = fopen($dbdir.$outfile, "a");  foreach($txtname as $txt){   if(file_exists($dbdir.$txt)){    //读取临时备份文件    $tdata = readfiles($dbdir.$txt);            //生成备份文件    $tbl = explode(".", $txt);    $str = "`".$tbl[0]."`{{".$tdata."}}";    if(fwrite($fpr, $str)){     echo $tbl[0]."...写入 $outfile 成功!<brn";    }else{     echo $tbl[0]."...写入 $outfile 失败!<brn";    }        @unlink($dbdir.$txt);   }  }  fclose($fpr); }else{//恢复数据  $tdata = readfiles($dbdir.$_POST["sqlfile"]);    preg_match_all("/`(.*)`{{(.*)}}/isU", $tdata, $data_ar);  foreach($data_ar[1] as $k = $tt){   if(empty($data_ar[2][$k])) continue;   $tfile = $dbdir.$tt.".txt";   $fp = fopen($tfile, "w");   if(fwrite($fp, $data_ar[2][$k])){    //清空表    $sql = "TRUNCATE TABLE `$tt`";    $db-query($sql);    //重新装入数据    $sql = "LOAD DATA LOW_PRIORITY INFILE '".$dbdir.$tt.".txt"."' INTO TABLE `$tt`";    if($db-query($sql)){     fclose($fp);     echo $tt."表数据恢复成功!<brn";     unlink($dbdir.$tt.".txt");    }else{     echo $tt."表数据恢复失败!<brn";    }   }     }  //echo $tdata;  //print_r($data_ar);  //exit; }}  /*   * 读取文件内容  * 参数 $file 为文件名及完整路径  * 返回文件内容  */ function readfiles($file){  $tdata = "";  $fp = fopen($file, "r");  if(filesize($file) <= 0) return;  while($data = fread($fp, filesize($file))){   $tdata .= $data;  }  fclose($fp);  return $tdata; }?

方法二:

想在PHP后台管理直接能够备份数据库,于是想呀想,一直没有什么思路,一开始是考虑用php来访问服务器安装mysql的目录,比如 /usr/local/mysql/data目录,直接把下面对应的文件进行备份,但是出现了问题:

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/mysql/)

第一、运行php的是apche的用户,比如是nobody,那么它一般是没有权限访问/usr/local/mysql/data目录的。

第二、就算能够访问,那么你如何能够把/usr/local/mysql/data目录下的文件拷贝出来呢?因为mysql在运行的时候是不运行访问的,那么nobody用户有权限停止mysql的服务,不可能!

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/mysql/)

越想越不对劲,没有办法,看能不能从PHP操作数据库入手,于是就去看了下phpMyadmin和Discuz!的代码,呵呵,于是偷抄了Discuz!的代码,形成了如下备份数据库的方法。

来源:https://www.tulaoshi.com/n/20160129/1494478.html

延伸阅读
标签: MySQL mysql数据库
在我转到wordpress之后第一个考虑的是它的数据库备份恢复问题,因为写bloger都知道,自己的blog记录的都是自己需要的宝贵的资料和文字,如果因为各种未知因素导致数据库崩溃或者空间商出了问题,丢失了数据的话,无疑是一种非常巨大的痛苦和损失。 所以在我blog里面有好几篇资料文章或者自己心得文章来讨论mysql数据库备份恢复和乱码问题。 ...
标签: SQLServer
  使用MYSQL进行数据库备份,又很正规的数据库备份方法,同其他的数据库服务器有相同的概念,但有没有想过,MySQL会有更简捷的使用文件目录的备份方法,而且又快有好。 一、数据备份捷径 因为这个方法没有得到官方正式文档的验证,我们暂称为试验吧。 目的:备份hostA主机中一个mysql数据库TestA,并恢复到到hostB机中 试验环境: ...
相信很多个人网站的站长,或者是独立Blog的博主,都有着备份数据库这样一个需求。当然WordPress这样插件非常丰富的Blog系统有好多能帮你完成这项任务的插件。如果您需要自己亲手来备份数据库的话,我贴一个Mysql自动备份脚本供大家参考,在国外网站上看到的,还是不错,实现了定期备份Mysql数据库,并且可以选在在每周的一天做指定目录下文件的...
相信很多个人网站的站长,或者是独立Blog的博主,都有着备份数据库这样一个需求。当然WordPress这样插件非常丰富的Blog系统有好多能帮你完成这项任务的插件。如果您需要自己亲手来备份数据库的话,我贴一个Mysql自动备份脚本供大家参考,在国外网站上看到的,还是不错,实现了定期备份Mysql数据库,并且可以选在在每周的一天做指定目录下文件的...
重要的是在表丢失和毁坏时备份数据库。如果系统发生崩溃,您就能够将表恢复到崩溃时刻的状态,并尽可能不丢失数据。同样,错发DROP DATABASE 或DROP TABLE 命令的用户可能会向您请求进行数据恢复。有时,这是由MySQL管理员引起的破坏,管理员试图通过使用像vi 或emacs 这样的编辑器直接编辑表文件而毁坏了它们。这样做对表来说肯定是干了坏事。...