您好,欢迎访问一九零五行业门户网

详解MYSQL的备份还原(PHP实现)_MySQL

bitscn.com手把手教你实现mysql的备份还原
示例代码用我比较熟悉的php,当然你看完并理解了其中的思路,相信你也可以快速地用你熟悉的语言自己写出来。
一、新建dbbackup类,设置默认参数。
class dbbackup {
    public $host='localhost';    //数据库地址
    public $user='root';    //登录名
    public $pwd='';    //密码
    public $database;    //数据库名
    public $charset='utf8';    //数据库连接编码:mysql_set_charset
}
二、添加数据库连接function。
/**
     * 连接数据库 ...
     */
    function db() {       
        $con = mysql_connect($this->host,$this->user,$this->pwd);
        if (!$con){
            die('could not connect');
        }
$db_selected = mysql_select_db($this->database, $con);
        if (!$db_selected) {
            die('can/'t use select db');
        }
mysql_set_charset($this->charset);//设置编码
return $con;
    }
三、查询数据库表集合
/**
     * 表集合 ...
     */
    function tblist() {
        $list=array();
$rs=mysql_query(show tables from $this->database);
        while ($temp=mysql_fetch_row($rs)) {
            $list[]=$temp[0];
        }
return $list;
    }
四、查询表结构
/**
     * 表结构sql ...
     */
    function sqlcreate() {
        $sql='';
$tb=$this->tblist();       
        foreach ($tb as $v) {
            $rs=mysql_query(show create table $v);
            $temp=mysql_fetch_row($rs);
            $sql.=-- 表的结构:{$temp[0]} --/r/n;
            $sql.={$temp[1]};
            $sql.=;-- --/r/n/r/n;
        }
        return $sql;
    }
注:$sql.=;-- --/r/n/r/n; 每句sql后面必须加上分号(;)分割,mysql导入才能识别。-- -- 是程序对sql语句分割的标识,可以自定义但必须是注释语句,否则影响sql语句。/r/n无实际意义用于文本美观
五、insert into语句
/**
     * 数据插入sql ...
     */
    function sqlinsert() {
        $sql='';
$tb=$this->tblist();       
        foreach ($tb as $v) {
            $rs=mysql_query(select * from $v);
            if (!mysql_num_rows($rs)) {//无数据返回
                continue;
            }       
            $sql.=-- 表的数据:$v --/r/n;
            $sql.=insert into `$v` values/r/n;       
            while ($temp=mysql_fetch_row($rs)) {
                $sql.='(';
                foreach ($temp as $v2) {
                    if ($v2===null) {
                        $sql.=null,;
                    }
                    else {
                        $v2=mysql_real_escape_string($v2);
                        $sql.='$v2',;
                    }                   
                }
                $sql=mb_substr($sql, 0, -1);
                $sql.=),/r/n;
            }
            $sql=mb_substr($sql, 0, -3);
            $sql.=;-- --/r/n/r/n;   
        }
return $sql;
    }
注:
1.无数据返回时必须跳出本次循环,避免生成多余代码
2.当字段值为(null)时,插入字符为(null)而不是('null'),没有单引号。3.$v2=mysql_real_escape_string($v2),这是必要的转义
4.mb_substr($sql, 0, -1)、mb_substr($sql, 0, -3),必须去除最后一个逗号(,) 否则sql语句出错5.$sql.=;-- --/r/n/r/n,详见第四步注
六、备份操作
/**
     * 备份 ...
     * @param $filename 文件路径
     */
    function beifen($filename) {
        $this->db();    //连接数据库
$sql=$this->sqlcreate();
        $sql2=$this->sqlinsert();       
        $data=$sql.$sql2;
return file_put_contents($filename, $data);
    }
七、还原操作
/**
     * 还原 ...
     * @param $filename 文件路径
     */
    function huanyuan($filename) {
        $this->db();    //连接数据库
//删除数据表
        $list=$this->tblist();
        $tb='';
        foreach ($list as $v) {
            $tb.=`$v`,;
        }
        $tb=mb_substr($tb, 0, -1);
        if ($tb) {
            $rs=mysql_query(drop table $tb);
            if ($rs===false) {
                return false;
            }
        }
//执行sql
        $str=file_get_contents($filename);
        $arr=explode('-- --', $str);
        array_pop($arr);
foreach ($arr as $v) {
            $rs=mysql_query($v);
            if ($rs===false) {
                return false;
            }
        }
return true;
    }
备份示例:
$x=new dbbackup();
$x->database='test';
$rs=$x->beifen('db.sql');
var_dump($rs);
还原示例:
$x=new dbbackup();
$x->database='test';
$rs=$x->huanyuan('db.sql');
var_dump($rs);
完整代码:
class dbbackup {
    public $host='localhost';    //数据库地址
    public $user='root';    //登录名
    public $pwd='';    //密码
    public $database;    //数据库名
    public $charset='utf8';    //数据库连接编码:mysql_set_charset
/**
     * 备份 ...
     * @param $filename 文件路径
     */
    function beifen($filename) {
        $this->db();    //连接数据库
$sql=$this->sqlcreate();
        $sql2=$this->sqlinsert();       
        $data=$sql.$sql2;
return file_put_contents($filename, $data);
    }
/**
     * 还原 ...
     * @param $filename 文件路径
     */
    function huanyuan($filename) {
        $this->db();    //连接数据库
//删除数据表
        $list=$this->tblist();
        $tb='';
        foreach ($list as $v) {
            $tb.=`$v`,;
        }
        $tb=mb_substr($tb, 0, -1);
        if ($tb) {
            $rs=mysql_query(drop table $tb);
            if ($rs===false) {
                return false;
            }
        }
//执行sql
        $str=file_get_contents($filename);
        $arr=explode('-- --', $str);
        array_pop($arr);
foreach ($arr as $v) {
            $rs=mysql_query($v);
            if ($rs===false) {
                return false;
            }
        }
return true;
    }
/**
     * 连接数据库 ...
     */
    function db() {       
        $con = mysql_connect($this->host,$this->user,$this->pwd);
        if (!$con){
            die('could not connect');
        }
$db_selected = mysql_select_db($this->database, $con);
        if (!$db_selected) {
            die('can/'t use select db');
        }
mysql_set_charset($this->charset);    //设置编码
return $con;
    }
/**
     * 表集合 ...
     */
    function tblist() {
        $list=array();
$rs=mysql_query(show tables from $this->database);
        while ($temp=mysql_fetch_row($rs)) {
            $list[]=$temp[0];
        }
return $list;
    }
/**
     * 表结构sql ...
     */
    function sqlcreate() {
        $sql='';
$tb=$this->tblist();       
        foreach ($tb as $v) {
            $rs=mysql_query(show create table $v);
            $temp=mysql_fetch_row($rs);
            $sql.=-- 表的结构:{$temp[0]} --/r/n;
            $sql.={$temp[1]};
            $sql.=;-- --/r/n/r/n;
        }
        return $sql;
    }
/**
     * 数据插入sql ...
     */
    function sqlinsert() {
        $sql='';
$tb=$this->tblist();       
        foreach ($tb as $v) {
            $rs=mysql_query(select * from $v);
            if (!mysql_num_rows($rs)) {//无数据返回
                continue;
            }       
            $sql.=-- 表的数据:$v --/r/n;
            $sql.=insert into `$v` values/r/n;       
            while ($temp=mysql_fetch_row($rs)) {
                $sql.='(';
                foreach ($temp as $v2) {
                    if ($v2===null) {
                        $sql.=null,;
                    }
                    else {
                        $v2=mysql_real_escape_string($v2);
                        $sql.='$v2',;
                    }                   
                }
                $sql=mb_substr($sql, 0, -1);
                $sql.=),/r/n;
            }
            $sql=mb_substr($sql, 0, -3);
            $sql.=;-- --/r/n/r/n;   
        }
return $sql;
    }
}
//备份
//$x=new dbbackup();
//$x->database='test';
//$rs=$x->beifen('db.sql');
//var_dump($rs);
//还原
//$x=new dbbackup();
//$x->database='test';
//$rs=$x->huanyuan('db.sql');
//var_dump($rs);
bitscn.com
其它类似信息

推荐信息