程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> 詳解MYSQL的備份復原(PHP完成)

詳解MYSQL的備份復原(PHP完成)

編輯:MySQL綜合教程

詳解MYSQL的備份復原(PHP完成)。本站提示廣大學習愛好者:(詳解MYSQL的備份復原(PHP完成))文章只能為提供參考,不一定能成為您想要的結果。以下是詳解MYSQL的備份復原(PHP完成)正文


手把手教你完成MYSQL的備份復原
示例代碼用我比擬熟習的PHP,固然你看完並懂得了個中的思緒,信任你也能夠疾速地用你熟習的說話本身寫出來。
1、新建dbBackup類,設置默許參數。

class dbBackup {
    public $host='localhost';    //數據庫地址
    public $user='root';    //登錄名
    public $pwd='';    //暗碼
    public $database;    //數據庫名
    public $charset='utf8';    //數據庫銜接編碼:mysql_set_charset
}

2、添加數據庫銜接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;
    }

3、查詢數據庫表聚集

/**
     * 表聚集 ...
     */
    function tblist() {
        $list=array();

        $rs=mysql_query("SHOW TABLES FROM $this->database");
        while ($temp=mysql_fetch_row($rs)) {
            $list[]=$temp[0];
        }

        return $list;
    }

4、查詢表構造

/**
     * 表構造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.=";-- <xjx> --\r\n\r\n";
        }
        return $sql;
    }

注:$sql.=";-- <xjx> --\r\n\r\n"; 每句SQL前面必需加上分號(;)朋分,MYSQL導入能力辨認。-- <xjx> -- 是法式對SQL語句朋分的標識,可以自界說但必需是正文語句,不然影響SQL語句。\r\n無現實意義用於文本雅觀

5、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.=";-- <xjx> --\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.=";-- <xjx> --\r\n\r\n",詳見第四步注

6、備份操作

/**
     * 備份 ...
     * @param $filename 文件途徑
     */
    function beifen($filename) {
        $this->db();    //銜接數據庫

        $sql=$this->sqlcreate();
        $sql2=$this->sqlinsert();       
        $data=$sql.$sql2;

        return file_put_contents($filename, $data);
    }

7、復原操作

/**
     * 復原 ...
     * @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('-- <xjx> --', $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('-- <xjx> --', $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.=";-- <xjx> --\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.=";-- <xjx> --\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);
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved