MySQL数据库备份恢复的两个实用方法
作者:20733 发布时间:2008-12-31 15:09:00
方法1:
/*
* 功能:数据备份/恢复文件简易方法
* 以日期为单位,一天一个备份文件,以当天最后备份为准
* 用提交表单的形式进行操作,
* 其中$_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 成功!
\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;
}
?>
猜你喜欢
- 1.比喻 如同Windows用桌面、文件夹、垃圾筒来比喻计算机的*作,Web的设计也是如此。善于利用明确、抽象或概念化的比喻ICON来表达各
- FileUpload上传图片(图片不变形) 的实现方法,需要的朋友可以参考下。<style type="text/css&q
- 昨天用ucweb看到了goos发的一篇帖子:谁说Float菜单不可以水平居中,进去看了看,觉得方法有点繁琐了,用到了负边距,position
- 虽然有很多种方式可以解决这个问题,但是我们可以用T-SQL代码来处理这个文件删除过程。我用xp_cmdshell命令和FORFILES命令来
- 可以在Mac OS X 10.2.x(“Jaguar”)和以上版本上Mac OS X使用二进制安装软件包的PKG格式代替二进制分发版来安装M
- 要想更好的理解 css, 尤其是 IE 下对 css 的渲染,haslayout 是一个非常有必要彻底弄清除的概念。大多IE下的显示错误,就
- 下面这个例子描述的是在Godaddy-Linux托管帐户上使用JSP连接到某个MySQL数据库。 <%@ page
- 此文刊登在《程序员》三月期,有删改提到安全问题,首先想到应付这些问题的应该是系统管理员以及后台开发工程师们,而前端开发工程师似乎离这些问题很
- onactivate
- 虽然现在有许多网页制作工具能让您轻松地完成工作,但如果使用HTML则可以得到更大控制权,下面介绍几个小技巧。1.使用语句来控制文字排版比用好
- 首先打击我的就是rpm安装,它告诉我发现了Mysql版本冲突,安装无法继续。我用rpm -q 查询后,想通过rpm -e 来删除系统自带的版
- 在Dreamweaver4中,你可以存储你自己设定的图片、链接、flash影片、颜色表、模板等等,组成这个站点的资产,这就是Assets面板
- 如何用OdbcRegTool组件来创建一个数据源?OdbcRegTool是一个免费组件,在服务器上安装后,就可以来创建一个数据源:<h
- 前阵子刚完成一个B/S架构的学校办公系统,体会就是表太多,文件太多,而每个文件中类似的操作(代码)也太多了,例如学生信息和教师信息操作,st
- 可用性研究表明,当响应时间超过一秒钟时,用户便能够有所察觉。虽然在反馈系统中,当用户需要等待时,更好的解决方案的是应该采用确定性的进度条。但
- 生成Fiboncci Fn数有Θ(1),Θ(n)甚至指数级的算法,不过有Θ(log n)的吗?告诉你,有。首先,关于Fibonacci数,有
- 很久以前写过如何成为优秀的设计师,近半年来经常做设计评审,有很多感触,顺便写一点下来,我们的Blog也应该有更高的更新频率。言归正传,我认为
- 有这么一个题目,说bt其实也不bt,为了重点突出其中的意图,特意加上了括号:var a = (++Math.P
- 作者的BLOG:http://www.planabc.net/地图弹窗(map pop)具体演示运行代码框<!DOCTYPE html
- 如何在线修改表?具体代码如下:<%Set conn1 = Server.CreateObject(&qu