程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> 一個簡單php數據庫備份程序

一個簡單php數據庫備份程序

編輯:關於PHP編程

php備份mysql數據庫是很多個人站長網站所具備的功能,當然如果你要備份幾個GB或更大的數據庫時php備份方法感覺有點吃力了。

PHP 備份 mysql 數據庫的源代碼,在完善的 PHP+Mysql 項目中,在後台都會有備份 Mysql 數據庫的功能,有了這個功能,我們就不用再使用 FTP 或者使用 mysql 的管理工具進行 mysql 數據庫下載了,非常方便,對於想做這樣功能的 phper 來說,其實原理並不是很麻煩,主要有以下三點:

一,一定要連接數據庫,這樣才能通過 SQL 語句打印出 mysql 數據表,二,通過 PHP 的文件操作函數進行數據庫的操作,包括創建保存 mysql 數據庫的文件夾,這一步主要就是新建文件的步驟,三,將 mysql 數據庫進行保存下來。

通過這樣的原理,我們就可以制作出一個屬於自己的備份數據庫的功能了,下面是一個php數據庫備份的源代碼,主要結構是依據上面的三點進行的,源碼是由幾個方法組成的,我們也可以將其封裝成為自己的 php 類。舉一反三,希望 phper 能在此基礎上設計出適合自己的 mysql 數據庫備份功能源碼

 代碼如下 復制代碼

<?php
/** 備份數據庫 生成.sql文件
     * @param $browseinfo  String  浏覽器版本
     * return $browseinfo
     */
    function createsql(){
        //創建個日期
        $timer1 = time();
        $path = "my_sql/";
        $content =gettables();
        $filename = $path.$timer1.".sql";
  
        //先判斷文件夾在不在
         if(!file_exists($path)){
        //如果不存在生成這個目錄,0777表示最大的讀寫權限
            if(mkdir($path,0777)){
            //echo"新建立目錄"; 
            }
        }

        //判斷文件是否存在
        if(!file_exists($filename)){
            //如果文件不存在,則創建文件
            @fopen($filename,"w");

            //判斷文件是否可寫
            if(is_writable($filename)){
            //打開文件以添加方式即"a"方式打開文件流
                if(!$handle =  fopen($filename,"a")){
                    echo"文件不可打開";
                    exit();
                }

            if(!fwrite($handle,$content)){
                echo"文件不可寫";
                exit();
            }

        //關閉文件流
        fclose($handle);
        echo "生成文件並保存首次內容";
       
    }else {
        echo"文件$filename不可寫";
    }
        }else{
            if(is_writable($filename)){
            //以添加方式打開文件流
            if(!$handle = fopen($filename,"a")){
                echo"文件不可打開";
                exit();
            }
            fclose($handle);
            }else{
                echo "文件$filename不可寫";
            }
    }
}


    /**
     * 獲得數據庫中的表名
     * return $str 循環生成數據庫建表和插入值的sql語句
     */
    function gettables(){
        $mysqli = new mysqli("localhost","root","","bbs");
        $str = '';
        if ($result = $mysqli->query("SHOW TABLES")) {
            while($row = $result->fetch_row()){
                $str.= data2sql($row[0])."<br/>";
            }
            $mysqli->close();
            return $str;
        }  
   
    }
   

    /**
     * 獲得數據庫中的表結構和值
     * return $tabledump 返回一個表中的結構和值的sql語句
     */
    function data2sql($table){ 
     $mysqli = new mysqli("localhost","root","","bbs");
        /* check connection */
        if (mysqli_connect_errno()) {
            printf("Connect failed: %sn", mysqli_connect_error());
        exit();
    }
         $tabledump = "DROP TABLE IF EXISTS $table;n";
         $result = $mysqli->query("SHOW CREATE TABLE $table");
         $create = $result->fetch_row();
         $tabledump .= $create[1].";nn";
 
         $rows = $mysqli->query("SELECT * FROM $table");
         $numfields = $rows->num_rows;

            while ($row = $rows->fetch_row()){
             $comma = "";
             $tabledump .= "INSERT INTO $table VALUES(";
              for($i = 0; $i < $numfields; $i++)
              {
                 $tabledump .= $comma."'".mysql_escape_strin
g($row[$i])."'";
                 $comma = ",";
              }
             $tabledump .= ");n";
          }
         $tabledump .= "n";
 
          return $tabledump;
      }
?>

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved