欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

php數(shù)據(jù)備份本地 phpstudy備份數(shù)據(jù)庫

如何用php進行數(shù)據(jù)備份

1、如果服務(wù)器允許mysqldump 并且沒有禁止PHP的shell_exec()這個函數(shù)的話

網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、重慶小程序開發(fā)公司、集團企業(yè)網(wǎng)站建設(shè)等服務(wù)項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了大豐免費建站歡迎大家使用!

直接在PHP里面執(zhí)行mysqldump就可以了。

2、通過mysql_query('show tables')的返回值遍歷每個表,循環(huán)對每個表使用查詢語句

select * into outfile '路徑/文件名' from 表名

缺點是這樣得到的是純數(shù)據(jù),恢復(fù)數(shù)據(jù)的時候你需要額外再寫腳本

3、同樣通過show tables返回表名,遍歷每個表,通過select 語句查詢,然后逐條結(jié)果處理,比如手工添加drop table 和create table 以及insert into等等,然后再寫入文件。這樣得到的備份數(shù)據(jù)是比較接近mysqldump的結(jié)果的,各種工具都可以用來恢復(fù)數(shù)據(jù)。缺點是如果數(shù)據(jù)庫太大的話,效率不好說

php 網(wǎng)站只要備份數(shù)據(jù)庫就可以嗎?

備份數(shù)據(jù)庫的數(shù)據(jù)就可以了。

備份的方法:

1、本地備份-適用于獨立主機或VPS:使用本機程序?qū)W(wǎng)站文件及數(shù)據(jù)庫進行備份。

2、異地備份-適用于虛擬主機/空間:使用FTP程序?qū)⑽募螺d回本機備份,數(shù)據(jù)庫使用本機的數(shù)據(jù)庫管理程序進行遠程備份。

備份的類型:

1、完整備份-所整個網(wǎng)站的文件都備份一次。優(yōu)點:可以把整個網(wǎng)站都完整備份一次。缺點:費時費資源。

2、差異備份-只備份有改變的文件。優(yōu)點:每次只把有改變過的文件備份下來。相同的文件就不會再備份一次了,省時省力。

如何用PHP來實現(xiàn)MySQL備份

備份數(shù)據(jù)庫并下載到本地【db_backup.php】

?php?

//?設(shè)置SQL文件保存文件名?

$filename=date("Y-m-d_H-i-s")."-".$cfg_dbname.".sql";?

//?所保存的文件名?

header("Content-disposition:filename=".$filename);?

header("Content-type:application/octetstream");?

header("Pragma:no-cache");?

header("Expires:0");?

//?獲取當(dāng)前頁面文件路徑,SQL文件就導(dǎo)出到此文件夾內(nèi)?

$tmpFile?=?(dirname(__FILE__))."\\".$filename;?

//?用MySQLDump命令導(dǎo)出數(shù)據(jù)庫?

exec("mysqldump?-u$cfg_dbuser?-p$cfg_dbpwd?--default-character-set=utf8?$cfg_dbname??".$tmpFile);?

$file?=?fopen($tmpFile,?"r");?//?打開文件?

echo?fread($file,filesize($tmpFile));?

fclose($file);?

exit;?

?

php,mysql數(shù)據(jù)庫備份和還原的最理想方式,類似phpadmin的代碼

一、備份數(shù)據(jù)庫并下載到本地【db_backup.php】

復(fù)制代碼 代碼如下:

?php

// 設(shè)置SQL文件保存文件名

$filename=date("Y-m-d_H-i-s")."-".$cfg_dbname.".sql";

// 所保存的文件名

header("Content-disposition:filename=".$filename);

header("Content-type:application/octetstream");

header("Pragma:no-cache");

header("Expires:0");

// 獲取當(dāng)前頁面文件路徑,SQL文件就導(dǎo)出到此文件夾內(nèi)

$tmpFile = (dirname(__FILE__))."\\".$filename;

// 用MySQLDump命令導(dǎo)出數(shù)據(jù)庫

exec("mysqldump -u$cfg_dbuser -p$cfg_dbpwd --default-character-set=utf8 $cfg_dbname ".$tmpFile);

$file = fopen($tmpFile, "r"); // 打開文件

echo fread($file,filesize($tmpFile));

fclose($file);

exit;

?

二、還原數(shù)據(jù)庫【db_restore.php】

復(fù)制代碼 代碼如下:

form id="form1" name="form1" method="post" action=""

【數(shù)據(jù)庫SQL文件】:input id="sqlFile" name="sqlFile" type="file" /

input id="submit" name="submit" type="submit" value="還原" /

/form

?php

// 我的數(shù)據(jù)庫信息都存放到config.php文件中,所以加載此文件,如果你的不是存放到該文件中,注釋此行即可;

require_once((dirname(__FILE__).'/../../include/config.php'));

if ( isset ( $_POST['sqlFile'] ) )

{

$file_name = $_POST['sqlFile']; //要導(dǎo)入的SQL文件名

$dbhost = $cfg_dbhost; //數(shù)據(jù)庫主機名

$dbuser = $cfg_dbuser; //數(shù)據(jù)庫用戶名

$dbpass = $cfg_dbpwd; //數(shù)據(jù)庫密碼

$dbname = $cfg_dbname; //數(shù)據(jù)庫名

set_time_limit(0); //設(shè)置超時時間為0,表示一直執(zhí)行。當(dāng)php在safe mode模式下無效,此時可能會導(dǎo)致導(dǎo)入超時,此時需要分段導(dǎo)入

$fp = @fopen($file_name, "r") or die("不能打開SQL文件 $file_name");//打開文件

mysql_connect($dbhost, $dbuser, $dbpass) or die("不能連接數(shù)據(jù)庫 $dbhost");//連接數(shù)據(jù)庫

mysql_select_db($dbname) or die ("不能打開數(shù)據(jù)庫 $dbname");//打開數(shù)據(jù)庫

echo "p正在清空數(shù)據(jù)庫,請稍等....br";

$result = mysql_query("SHOW tables");

while ($currow=mysql_fetch_array($result))

{

mysql_query("drop TABLE IF EXISTS $currow[0]");

echo "清空數(shù)據(jù)表【".$currow[0]."】成功!br";

}

echo "br恭喜你清理MYSQL成功br";

echo "正在執(zhí)行導(dǎo)入數(shù)據(jù)庫操作br";

// 導(dǎo)入數(shù)據(jù)庫的MySQL命令

exec("mysql -u$cfg_dbuser -p$cfg_dbpwd $cfg_dbname ".$file_name);

echo "br導(dǎo)入完成!";

mysql_close();

}

?

php怎么備份數(shù)據(jù)庫

1.打開數(shù)據(jù)庫備份頁面

//php代碼,導(dǎo)出數(shù)據(jù)庫

public function exportSql() {

$dbName = C('DB_NAME'); //讀取配置文件中的數(shù)據(jù)庫用戶名、密碼、數(shù)據(jù)庫名

$dbUser = C('DB_USER');

$dbPwd = C('DB_PWD');

$fileName = date("Y-m-d")."_".$dbName.".sql";

$dumpFileName = "./sql_backup/".$fileName;

exec("D:/xampp/mysql/bin/mysqldump -u$dbUser -p$dbPwd $dbName $dumpFileName");

}

2.php exec函數(shù),執(zhí)行外部程序命令

exec(“D:/xampp/mysql/bin/mysqldump -u$dbUser -p$dbPwd $dbName $dumpFileName”);

此處執(zhí)行mysqldump命令,導(dǎo)出數(shù)據(jù)庫到$dumpFileName中,“D:/xampp/mysql/bin/”為mysqldump所在位置,“-u$dbUser -p$dbPwd”數(shù)據(jù)庫的用戶名和密碼(中間不要加空格),$dbName為要導(dǎo)出數(shù)據(jù)庫的名字

本文名稱:php數(shù)據(jù)備份本地 phpstudy備份數(shù)據(jù)庫
分享網(wǎng)址:http://www.chinadenli.net/article46/dodcjeg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作電子商務(wù)服務(wù)器托管網(wǎng)站改版網(wǎng)站策劃虛擬主機

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

綿陽服務(wù)器托管