$msgs[]="服務(wù)器備份目錄為backup";
成都創(chuàng)新互聯(lián)是一家專業(yè)提供西吉企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站設(shè)計制作、做網(wǎng)站、H5技術(shù)、小程序制作等業(yè)務(wù)。10年已為西吉眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)絡(luò)公司優(yōu)惠進(jìn)行中。
$msgs[]="對于較大的數(shù)據(jù)表,強(qiáng)烈建議使用分卷備份";
$msgs[]="只有選擇備份到服務(wù)器,才能使用分卷備份功能";
show_msg($msgs);
php簡單備份與還原MySql的方法具體如下:
一、備份:
?php
header?(?"content-Type:?text/html;?charset=utf-8"?);
//備份數(shù)據(jù)庫
$host="localhost";
$user="root";//數(shù)據(jù)庫賬號
$password="123456";//數(shù)據(jù)庫密碼
$dbname="test";//數(shù)據(jù)庫名稱
//這里的賬號、密碼、名稱都是從頁面?zhèn)鬟^來的
if(!mysql_connect($host,$user,$password))?//連接mysql數(shù)據(jù)庫
{
echo?'數(shù)據(jù)庫連接失敗,請核對后再試';
exit;
}
if(!mysql_select_db($dbname))?//是否存在該數(shù)據(jù)庫
{
echo?'不存在數(shù)據(jù)庫:'.$dbname.',請核對后再試';
exit;
}
mysql_query("set?names?'utf8'");
$mysql=?"set?charset?utf8;\r\n";
$q1=mysql_query("show?tables");
while($t=mysql_fetch_array($q1)){
$table=$t[0];
$q2=mysql_query("show?create?table?`$table`");
$sql=mysql_fetch_array($q2);
$mysql.=$sql['Create?Table'].";\r\n";
$q3=mysql_query("select?*?from?`$table`");
while($data=mysql_fetch_assoc($q3)){
$keys=array_keys($data);
$keys=array_map('addslashes',$keys);
$keys=join('`,`',$keys);
$keys="`".$keys."`";
$vals=array_values($data);
$vals=array_map('addslashes',$vals);
$vals=join("','",$vals);
$vals="'".$vals."'";
$mysql.="insert?into?`$table`($keys)?values($vals);\r\n";
}
}
$filename="data/".$dbname.date('Ymjgi').".sql";?//存放路徑,默認(rèn)存放到項目最外層
$fp?=?fopen($filename,'w');
fputs($fp,$mysql);
fclose($fp);
echo?"數(shù)據(jù)備份成功";
?
二、還原
!--
author:果凍
qq:52091199
blog:
--
meta?http-equiv="Content-Type"?content="text/html;?charset=utf-8"?/
?php
$filename?=?"test20101216923.sql";
$host="localhost";?//主機(jī)名
$user="root";?//MYSQL用戶名
$password="123456";?//密碼
$dbname="test";?//在此指定您要恢復(fù)的數(shù)據(jù)庫名,不存在則必須先創(chuàng)建,請自已修改數(shù)據(jù)庫名
mysql_connect($host,$user,$password);
mysql_select_db($dbname);
$mysql_file="data/".$filename;?//指定要恢復(fù)的MySQL備份文件路徑,請自已修改此路徑
restore($mysql_file);?//執(zhí)行MySQL恢復(fù)命令
function?restore($fname)
{
if?(file_exists($fname))?{
$sql_value="";
$cg=0;
$sb=0;
$sqls=file($fname);
foreach($sqls?as?$sql)
{
$sql_value.=$sql;
}
$a=explode(";\r\n",?$sql_value);?//根據(jù)";\r\n"條件對數(shù)據(jù)庫中分條執(zhí)行
$total=count($a)-1;
mysql_query("set?names?'utf8'");
for?($i=0;$i$total;$i++)
{
mysql_query("set?names?'utf8'");
//執(zhí)行命令
if(mysql_query($a[$i]))
{
$cg+=1;
}
else
{
$sb+=1;
$sb_command[$sb]=$a[$i];
}
}
echo?"操作完畢,共處理?$total?條命令,成功?$cg?條,失敗?$sb?條";
//顯示錯誤信息
if?($sb0)
{
echo?"hrbrbr失敗命令如下:br";
for?($ii=1;$ii=$sb;$ii++)
{
echo?"pb第?".$ii."?條命令(內(nèi)容如下):/bbr".$sb_command[$ii]."/pbr";
}
}??//-----------------------------------------------------------
}else{
echo?"MySQL備份文件不存在,請檢查文件路徑是否正確!";
}
}
?
是。因為php代碼實現(xiàn)數(shù)據(jù)庫備份可以使網(wǎng)站的管理變得非常便捷,我們可以直接進(jìn)后臺操作就能完成數(shù)據(jù)庫的備份,還可以對腳本文件進(jìn)行刪除、覆蓋等操作。php腳本就是程序,一般都是有應(yīng)用程序提供的編程語言。
phpcms可以使用多備份進(jìn)行數(shù)據(jù)庫備份
根據(jù)phpcms的運(yùn)行環(huán)境,可以選擇web模式備份或者客戶端備份
虛擬主機(jī)環(huán)境可以選擇web模式備份。登陸多備份官網(wǎng)后進(jìn)入多備份控制面板,如果是首次登陸會有備份環(huán)境選項,選擇保護(hù)服務(wù)器
選擇web模式,然后選擇數(shù)據(jù)庫備份。如果非首次登陸直接選擇添加,然后選擇數(shù)據(jù)庫備份
選擇好以后添加數(shù)據(jù)庫參數(shù),選擇備份頻率,創(chuàng)建任務(wù)即可。
如果是服務(wù)器環(huán)境,首先進(jìn)入多備份控制面板,首次登陸會有備份環(huán)境,然后選擇保護(hù)服務(wù)器,下載對應(yīng)的客戶端。如果非首次登陸,直接下載左下角的客戶端
下載好以后解壓,打開dbfen.exe,然后登陸多備份賬號,選擇數(shù)據(jù)庫備份,然后填入數(shù)據(jù)庫參數(shù),選擇備份頻率,即可開始備份
先說代碼,我看了一下,代碼沒什么問題,至于你說的不備份,原因可能如下:
查詢無結(jié)果,測試辦法是在最外層的那個while語句結(jié)束后輸出查詢語句,即:
while?($t?=?mysql_fetch_array($q1))
{
//里面的代碼
}
echo?$mysql;//在這里輸出查詢結(jié)果,如果結(jié)果正常,則說明查詢有結(jié)果
$filename?=?"autobackup.sql";?//存放路徑,默認(rèn)存放到項目最外層
然后就是另一個問題了,目標(biāo)文件不可寫,你可以參考下面這樣的代碼
$filename?=?"autobackup.sql";?//存放路徑,默認(rèn)存放到項目最外層
if(!file_exists($filename)?||?is_writable($filename))//如果文件不存在或可寫
{
$fp?=?fopen($filename,?'w');//打開或創(chuàng)建可寫文件
$mysql=str_replace("','','');","',null,null);",$mysql);
fputs($fp,?$mysql);//寫入
fclose($fp);
}
else
{
echo?"文件?$filename?不存在或不可寫";
}
如果嘗試發(fā)現(xiàn)仍有問題,請再追問