?php
成都創(chuàng)新互聯(lián)公司堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都做網(wǎng)站、成都網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的益陽(yáng)網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
/*
**************function?db_bak()********************
*??功能:備份指定的數(shù)據(jù)庫(kù)中的指定表
*??輸入(按傳入?yún)?shù)解釋):$db_name?要備份的數(shù)據(jù)庫(kù),$tb_array要備份的表,數(shù)組形式的,如果不是數(shù)組,將備份整個(gè)庫(kù)。
$dir輸出備份文件的目錄,$filename備份文件名,$block_num指定分塊大?。ㄖ敢粭linsert語(yǔ)句包含幾天數(shù)據(jù))
*??輸出:備份的數(shù)據(jù)表的sql語(yǔ)句文件,可用于還原
*/
function?db_bak($mylink,$dbname,$tab_array="",$dir,$filename,$block_num=20){
mysql_select_db($dbname,$mylink)?or?db_error(mysql_error());
is_array($tab_array)?or?$tab_array=db_showtb($mylink,$dbname,true);?//如果$tab_array不是數(shù)組,則取得整個(gè)庫(kù)的表
if($dir){
if(!file_exists($dir)){
$flag=mkdir($dir);
if(!$flag)
return?2;
}
}
//檢查數(shù)據(jù)表是否存在
foreach($tab_array?as?$tab)
db_e_tab($mylink,$dbname,$tab)?or?db_error($tab."?is?not?exist!");
$fp=fopen($dir.$filename,"w");
foreach($tab_array?as?$tab){??
fputs($fp,"DROP?TABLE?IF?EXISTS?".$tab.";\r\n");
$tabdef_array=mysql_fetch_array(mysql_query("SHOW?CREATE?TABLE?".$tab,$mylink));
fputs($fp,str_replace("\n","",$tabdef_array["Create?Table"]).";\r\n");?
fputs($fp,"LOCK?TABLES?".$tab."?WRITE;\r\n");?
$getvalue_result=mysql_query("select?*?from?".$tab,$mylink);
if(mysql_num_rows($getvalue_result)){
$i=1;??
$p="";
$start_flag=true;
while($getvalue_array=mysql_fetch_row($getvalue_result)){
$values=join("','",array_map('db_data_check',$getvalue_array));
$start_flag??fputs($fp,"insert?into?".$tab."?values");
if($i$block_num){
fputs($fp,",('".$values."');\r\n");
$start_flag=true;
$i=0;
}else{
fputs($fp,$p."('".$values."')");
$start_flag=false;
$i++;
}
$p=$start_flag?"":",";?
}
$start_flag?or?fputs($fp,";\r\n");
}
fputs($fp,"UNLOCK?TABLES;\r\n");??
}
fclose($fp);??
}
/*
**************function?db_in()********************
*??功能:還原備份函數(shù)db_bak生成的數(shù)據(jù)庫(kù)文件
*??輸入(按傳入?yún)?shù)解釋):$db_name?要備份的數(shù)據(jù)庫(kù),$filename要還原的數(shù)據(jù)庫(kù)文件
*??輸出:將數(shù)據(jù)還原到數(shù)據(jù)庫(kù)
*??原理:將文件分割成一個(gè)數(shù)組,然后逐條將數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫(kù)
*??警告:執(zhí)行該函數(shù)會(huì)刪除原來(lái)的數(shù)據(jù)表
*/
function?db_in($mylink,$dbname,$filename){
if(!file_exists($filename)){
return?0;
}
db_e_db($mylink,$dbname)?or?(mysql_query("create?database?".$dbname,$mylink)or?db_error(mysql_error()));
mysql_select_db($dbname,$mylink);
$sql_array=file($filename);
foreach($sql_array?as?$sql){
mysql_query(trim($sql),$mylink)?or?db_error(mysql_error());
}
}
??
//我自己寫的??梢詤⒖脊?/p>
步驟如下
1、首先把要把sql2012中要備份的數(shù)據(jù)庫(kù)設(shè)置為兼容2008.
右鍵sql2012中的數(shù)據(jù)庫(kù)Test-屬性-選項(xiàng)
2、右鍵Test-任務(wù)-生成腳本,下一步-下一步 ,點(diǎn) 高級(jí) 選項(xiàng)。把script for sql version 改成你要降級(jí)的那個(gè)版本 也就是sql2008.確定完成即可。會(huì)生成一個(gè)script.sql腳本文件。
3、下一步要把sqlserver2012源文件復(fù)制到另外一個(gè)電腦上。由于SqlServer正在運(yùn)行 是無(wú)法復(fù)制的。所以首先要停止sqlserver服務(wù)。
3、找到你這個(gè)sql2012數(shù)據(jù)庫(kù)在電腦中的位置。 右鍵這個(gè)數(shù)據(jù)庫(kù)-文件 會(huì)有路徑,復(fù)制出這兩個(gè)文件來(lái)。 至此 sqlserver2012的電腦操作完成
4、把上面得到的script.sql 文件和兩個(gè)數(shù)據(jù)源文件復(fù)制到sql2008所在的電腦中。在sql2008中 新建-查詢管理器。把script.sql拖進(jìn)去,會(huì)看到代碼。
能生成文件但是內(nèi)容為空,說(shuō)明:php執(zhí)行沒(méi)問(wèn)題,mysqldump也運(yùn)行,初步判斷問(wèn)題出在mysqldump沒(méi)正常運(yùn)行。建議你到服務(wù)器上運(yùn)行 "C:\Program Files\MySQL\MySQL Server 5.0\bin\mysqldump -uroot -hlocalhost -p123 --opt -B rsgl ../bak/xxx.sql"
看能否正常生成sql文件
1、如果服務(wù)器允許mysqldump 并且沒(méi)有禁止PHP的shell_exec()這個(gè)函數(shù)的話
直接在PHP里面執(zhí)行mysqldump就可以了。
2、通過(guò)mysql_query('show tables')的返回值遍歷每個(gè)表,循環(huán)對(duì)每個(gè)表使用查詢語(yǔ)句
select * into outfile '路徑/文件名' from 表名
缺點(diǎn)是這樣得到的是純數(shù)據(jù),恢復(fù)數(shù)據(jù)的時(shí)候你需要額外再寫腳本
3、同樣通過(guò)show tables返回表名,遍歷每個(gè)表,通過(guò)select 語(yǔ)句查詢,然后逐條結(jié)果處理,比如手工添加drop table 和create table 以及insert into等等,然后再寫入文件。這樣得到的備份數(shù)據(jù)是比較接近mysqldump的結(jié)果的,各種工具都可以用來(lái)恢復(fù)數(shù)據(jù)。缺點(diǎn)是如果數(shù)據(jù)庫(kù)太大的話,效率不好說(shuō)
有很多軟件可以使用,比如phpmyadmin,sqlyog等等
下載一個(gè)phpmyadmin并且配置好(網(wǎng)上有如何配置),其中就有備份還原數(shù)據(jù)庫(kù)的圖標(biāo),很簡(jiǎn)單
補(bǔ)充:----------------------
對(duì)啊,點(diǎn)導(dǎo)出,然后執(zhí)行就可以了啊