一個簡單phpDatabase Backup程式_PHP教程

來源:互聯網
上載者:User
php備份mysql資料庫是很多個人站長網站所具備的功能,當然如果你要備份幾個GB或更大的資料庫時php備份方法感覺有點吃力了。

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

一,一定要串連資料庫,這樣才能通過 SQL 陳述式列印出 mysql 資料表,二,通過 PHP 的檔案操作函數進行資料庫的操作,包括建立儲存 mysql 資料庫的檔案夾,這一步主要就是建立檔案的步驟,三,將 mysql 資料庫進行儲存下來。

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

代碼如下 複製代碼

/** 備份資料庫 產生.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])."
";
}
$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;
}
?>

http://www.bkjia.com/PHPjc/632928.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/632928.htmlTechArticlephp備份mysql資料庫是很多個人站長網站所具備的功能,當然如果你要備份幾個GB或更大的資料庫時php備份方法感覺有點吃力了。 PHP 備份 mys...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.