学院首页 软件应用 编程开发 创意设计 认证培训 软件论坛
ASP ASP.NET PHP JSP SQL MYSQL Java VB

您的位置:学院 >> 编程开发 >> MYSQL >> 一个MySQL数据备份/恢复的简易方法


一个MySQL数据备份/恢复的简易方法


方法一:

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 成功!
\n"; }else{ echo $tbl[0]."...写入 $outfile 失败!
\n"; } @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."表数据恢复成功!
\n"; unlink($dbdir.$tt.".txt"); }else{ echo $tt."表数据恢复失败!
\n"; } } } //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目录,直接把下面对应的文件进行备份,但是出现了问题:

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

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

越想越不对劲,没有办法,看能不能从php操作数据库入手,于是就去看了下phpMyadmin和Discuz!的代码,呵呵,于是偷抄了Discuz!的代码,形成了如下备份数据库的方法。(在这里感谢Discuz!的开发者)

备份数据库有两种方式,一种是只备份数据库的结构,一种把是结构和所有的数据都备份出来,当然是第二种方法好啦,不过我为了考虑可能的需求就都作啦。

/******  备份数据库结构 ******/

/*
函数名称:table2sql()
函数功能:把表的结构转换成为SQL
函数参数:$table: 要进行提取的表名
返 回 值:返回提取后的结果,SQL集合
函数作者:heiyeluren
*/

function table2sql($table) 
{
 global $db;
 $tabledump = "DROP TABLE IF EXISTS $table;\n";
 $createtable = $db->query("SHOW CREATE TABLE $table");
 $create = $db->fetch_row($createtable);
 $tabledump .= $create[1].";\n\n";

 return $tabledump;
}


/****** 备份数据库结构和所有数据 ******/
/*
函数名称:data2sql()
函数功能:把表的结构和数据转换成为SQL
函数参数:$table: 要进行提取的表名
返 回 值:返回提取后的结果,SQL集合
函数作者:heiyeluren
*/
function data2sql($table) 
{
 global $db;
 $tabledump = "DROP TABLE IF EXISTS $table;\n";
 $createtable = $db->query("SHOW CREATE TABLE $table");
 $create = $db->fetch_row($createtable);
 $tabledump .= $create[1].";\n\n";

 $rows = $db->query("SELECT * FROM $table");
 $numfields = $db->num_fields($rows);
 $numrows = $db->num_rows($rows);
 while ($row = $db->fetch_row($rows))
 {
  $comma = "";
  $tabledump .= "INSERT INTO $table VALUES(";
  for($i = 0; $i < $numfields; $i++) 
  {
   $tabledump .= $comma."'".mysql_escape_string($row[$i])."'";
   $comma = ",";
  }
  $tabledump .= ");\n";
 }
 $tabledump .= "\n";

 return $tabledump;
}


/****** 具体实现操作 ******/
好,我们既然把代码都写出来了,那么我们如何在具体的程序种去实现备份呢,我们看下面的代码。


/* 备份数据库 */
// 注意:我们一下的数据库操作采用了phplib的DB类

// 定义要保存的数据表、前缀、保存到何处
$tables = array('us_sort', 'us_download', 'us_article', 'us_guestbook'); //定义要保存的数据表,一个数组
$prefix = 'us_';    // 要保存的.sql文件的前缀
$saveto = 'server'; // 要保存到什么地方,是本地还是服务器上,默认是服务器
$back_mode = 'all'; // 要保存的方式,是全部备份还是只保存数据库结构
$admin = 'heiyeluren'; //管理员名称
$admin_email = 'heiyeluren@163.com';  // 管理员邮箱

// 定义数据保存的文件名
$local_filename = $prefix.date('Ymd_His').'.sql"';
if (!$filename) { $filename = $db_backup_path . $prefix . date('Ymd_His_'). create_check_code(4) . ".sql"; }
$filename = $prefix.date(Ymd_His). create_check_ code(6).".sql";      // 保存在服务器上的文件名
// 注意后面的create_check_code()函数,这是一个生成随机码的函数,详细可以参考:
// http://blog.csdn.net/heiyeshuwu/archive/2005/01/26/268446.aspx

// 获取数据库结构和数据内容
foreach($tables as $table) 
{
 if ($back_mode == 'all') { $sqldump .= data2sql($table); }
 if ($back_mode == 'table') { $sqldump .= table2sql($table); }
}

// 如果数据内容不是空就开始保存
if(trim($sqldump)) 
{
 // 写入开头信息
 $sqldump = 
  "# --------------------------------------------------------\n".
  "# 数据表备份\n".
  "#\n".
  "# 服务器: $db->Host\n".
  "# 数据库:$db->Database\n".
  "# 备份编号: ". create_sess_id() ."\n". // 这里有一个生成session id的函数
  "# 备份时间: ".time_to_date('',6)."\n". // 这里就是获取当前时间的函数
  "#\n".
  "# 管理员:$admin ($admin_email)\n". // 管理员的用户名和邮箱地址
  "# $copyright\n".
  "# --------------------------------------------------------\n\n\n".
  $sqldump;
 
 // 保存到本地
 if($saveto == "local") 
 {
  ob_end_clean();
  header('Content-Encoding: none');
  header('Content-Type: '.(strpos($HTTP_SERVER_VARS['HTTP_USER_AGENT'], 'MSIE') ?
 'application/octetstream' : 'application/octet-stream'));
  header('Content-Disposition: '.(strpos($HTTP_SERVER_VARS['HTTP_USER_AGENT'], 'MSIE') ?
 'inline; ' : 'attachment; ').'filename="'.$local_filename);
  header('Content-Length: '.strlen($sqldump));
  header('Pragma: no-cache');
  header('Expires: 0');
  echo $sqldump;
 } 
 // 保存到本地结束
 
 // 保存在服务器
 if($saveto == "server") 
 {
  if($filename != "") 
  {
   @$fp = fopen($filename, "w+");
   if ($fp)
   {
    @flock($fp, 3);
    if(@!fwrite($fp, $sqldump)) 
    {
     @fclose($fp);
     exit_msg("数据文件无法保存到服务器,请检查目录属性你是否有写的权限。");
    } 
    else 
    {
     exit_msg("数据成功备份至服务器 $filename 中。");
    }
   }
   else
   {
    exit_msg("无法打开你指定的目录". $filename .",请确定该目录是否存在,或者是否有相应权限"); 
   }
  } 
  else 
  {
   exit_msg("您没有输入备份文件名,请返回修改。");
  }
 }
 // 保存到服务器结束
}
else
{
 exit_msg("数据表没有任何内容");
}
/* 备份数据库结束 */

呵呵,基本上这样就结束了,然后涉及到的一个问题是如何把数据恢复到数据库中,我想这个是不复杂的,但是最好能够满足有从客户端和从服务器恢复数据的功能。

技术文章快速查找

栏目导航
软件应用
·操作系统 ·杀毒防黑 ·应用软件
·聊天软件 ·网络软件  
Web开发
·ASP ·JavaScript ·CGI
·JSP ·VbScript ·Web服务器
·PHP ·XML  
开发语言
·VB ·VC ·ASP.NET
·Java ·C/C++ ·Delphi
数据库开发
·MySQL ·SQL/Access ·PowerBuilder
·Oracle ·DB2  
网站设计
·Flash ·Dreamweaver ·HTML/CSS
·Fireworks ·FrontPage  
平面设计
·Photoshop ·CorelDraw ·AutoCAD
·FreeHand ·Illustrator ·3DsMAX
媒体动画
·Director ·Authorware ·Maya
·视频处理    


相关软件 产品库推荐
·笔记本 ·台式机 ·服务器
·数码相机 ·手机 ·GPS
·DV摄像机 ·MP3 ·MP4
·CPU ·硬盘 ·内存
·主板 ·显卡 ·显示器
·打印机 ·投影机 ·路由器

高手!看到你的帖子后,照着做了一个.有几个问题想问你!我的QQ:181911116...
游客 发表于2008-9-20 17:53:13
对"一个MySQL数据备份/恢复的简易方法"的评论 - 快速回贴
内容:
  [完成后可按Ctrl+Enter发布]

百度中 一个MySQL数据备份/恢复的简易方法 相关内容
Google搜索中 一个MySQL数据备份/恢复的简易方法 相关内容
雅虎中 一个MySQL数据备份/恢复的简易方法 相关内容
Sogou搜索中 一个MySQL数据备份/恢复的简易方法 相关内容

相关软件 最新回复帖子:

·一个MySQL数据备份/恢复的简易方法
·相同地点不同风貌 地图家族横向评测
·新年找个好工作 人才招聘软件2008详解
·企业如何选择微机平台三维CAD软件
·Fireworks精细描绘CS游戏中的枪支
·AutoCAD三维造型--弹簧的简单画法
·在Windows XP下直接修改硬盘分区容量
·nesox让电子邮件营销原来如此轻松!
·有消息称AutoCAD 2009简体中文版发布
·Freehand常用特色功能疑难解答


  相关软件 一个MySQL数据备份/恢复的简易方法相关文章
详细介绍MySQL数据库的备份与恢复问题 有关数据库的修复恢复基础知识简介
MySQL数据库简单的数据备份与恢复过程 教你在MySQL从口令恢复设置的密码
MySQL数据库的root口令恢复方法总结 如何使用MYSQL数据库进行备份数据恢复
教你如何将MySQL数据库的密码恢复 一个简单的MySQL备份恢复数据指令
在Linux异构网络中备份MYSQL数据库 实例教程:MySQL数据库密码恢复笔记
MySQL数据库下损坏数据的恢复操作 一个MySQL数据库的简易备份方法介绍
MySQL入门学习之修改、备份和批处理 有关MySQL的双机热备份问题杂谈
通过PHP来实现XML备份MySQL数据库 MySQL数据库的备份和恢复经验简介
两个机器上MYSQL的互为备份问题 有关MySQL的数据同步备份复制问题
MySQL数据库的安装备份与密码恢复 教你如何使用MYSQL来备份数据恢复