當前位置:才華齋>計算機>php語言>

備份php資料庫指令碼的方法

php語言 閱讀(2.94W)

之前是採用PHP讀取資料庫結構和內容,然後寫檔案,這樣可能會導致匯出的`檔案不一定能百分百匯入到MySQL中去,想想之後採用MySQL自帶的匯入匯出命令最保險。大家知道備份php資料庫指令碼嗎?

備份php資料庫指令碼的方法

  php資料庫備份指令碼

程式碼如下:

// 備份資料庫

$host = "localhost";

$user = "root"; //資料庫賬號

$password = ""; //資料庫密碼

$dbname = "mysql"; //資料庫名稱

// 這裡的賬號、密碼、名稱都是從頁面傳過來的

if (!mysql_connect($host, $user, $password)) // 連線mysql資料庫

{

echo '資料庫連線失敗,請核對後再試';

exit;

}

if (!mysql_select_db($dbname)) // 是否存在該資料庫

{

echo '不存在資料庫:' . $dbname . ',請核對後再試';

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') . ""; //存放路徑,預設存放到專案最外層

$fp = fopen($filename, 'w');

fputs($fp, $mysql);

fclose($fp);

echo "資料備份成功";

?>