備份php數(shù)據(jù)庫(kù)腳本的方法
之前是采用PHP讀取數(shù)據(jù)庫(kù)結(jié)構(gòu)和內(nèi)容,然后寫文件,這樣可能會(huì)導(dǎo)致導(dǎo)出的文件不一定能百分百導(dǎo)入到MySQL中去,想想之后采用MySQL自帶的導(dǎo)入導(dǎo)出命令最保險(xiǎn)。大家知道備份php數(shù)據(jù)庫(kù)腳本嗎?
php數(shù)據(jù)庫(kù)備份腳本
代碼如下:
// 備份數(shù)據(jù)庫(kù)
$host = "localhost";
$user = "root"; //數(shù)據(jù)庫(kù)賬號(hào)
$password = ""; //數(shù)據(jù)庫(kù)密碼
$dbname = "mysql"; //數(shù)據(jù)庫(kù)名稱
// 這里的賬號(hào)、密碼、名稱都是從頁(yè)面?zhèn)鬟^(guò)來(lái)的
if (!mysql_connect($host, $user, $password)) // 連接mysql數(shù)據(jù)庫(kù)
{
echo '數(shù)據(jù)庫(kù)連接失敗,請(qǐng)核對(duì)后再試';
exit;
}
if (!mysql_select_db($dbname)) // 是否存在該數(shù)據(jù)庫(kù)
{
echo '不存在數(shù)據(jù)庫(kù):' . $dbname . ',請(qǐng)核對(duì)后再試';
exit;
}
mysql_query("set names 'utf8'");
$mysql = "set charset utf8; ";
$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'] . "; ";
$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 .= " into `$table`($keys) values($vals); ";
}
}
$filename = $dbname . date('Ymjgi') . ".sql"; //存放路徑,默認(rèn)存放到項(xiàng)目最外層
$fp = fopen($filename, 'w');
fputs($fp, $mysql);
fclose($fp);
echo "數(shù)據(jù)備份成功";
?>
【備份php數(shù)據(jù)庫(kù)腳本的方法】相關(guān)文章:
PHP數(shù)據(jù)庫(kù)備份腳本的方法09-10
PHP數(shù)據(jù)庫(kù)備份腳本的方法技巧10-25
php備份數(shù)據(jù)庫(kù)類的方法09-04
PHP腳本測(cè)試連接MySQL數(shù)據(jù)庫(kù)10-11
PHP框架:CodeIgniter框架備份數(shù)據(jù)庫(kù)11-03
PHP腳本修改Linux系統(tǒng)口令的方法09-05