詳解MYSQL的備份復原(PHP完成)。本站提示廣大學習愛好者:(詳解MYSQL的備份復原(PHP完成))文章只能為提供參考,不一定能成為您想要的結果。以下是詳解MYSQL的備份復原(PHP完成)正文
手把手教你完成MYSQL的備份復原
示例代碼用我比擬熟習的PHP,固然你看完並懂得了個中的思緒,信任你也能夠疾速地用你熟習的說話本身寫出來。
1、新建dbBackup類,設置默許參數。
class dbBackup {
public $host='localhost'; //數據庫地址
public $user='root'; //登錄名
public $pwd=''; //暗碼
public $database; //數據庫名
public $charset='utf8'; //數據庫銜接編碼:mysql_set_charset
}
2、添加數據庫銜接function。
/**
* 銜接數據庫 ...
*/
function db() {
$con = mysql_connect($this->host,$this->user,$this->pwd);
if (!$con){
die('Could not connect');
}
$db_selected = mysql_select_db($this->database, $con);
if (!$db_selected) {
die('Can\'t use select db');
}
mysql_set_charset($this->charset); //設置編碼
return $con;
}
3、查詢數據庫表聚集
/**
* 表聚集 ...
*/
function tblist() {
$list=array();
$rs=mysql_query("SHOW TABLES FROM $this->database");
while ($temp=mysql_fetch_row($rs)) {
$list[]=$temp[0];
}
return $list;
}
4、查詢表構造
/**
* 表構造SQL ...
*/
function sqlcreate() {
$sql='';
$tb=$this->tblist();
foreach ($tb as $v) {
$rs=mysql_query("SHOW CREATE TABLE $v");
$temp=mysql_fetch_row($rs);
$sql.="-- 表的構造:{$temp[0]} --\r\n";
$sql.="{$temp[1]}";
$sql.=";-- <xjx> --\r\n\r\n";
}
return $sql;
}
注:$sql.=";-- <xjx> --\r\n\r\n"; 每句SQL前面必需加上分號(;)朋分,MYSQL導入能力辨認。-- <xjx> -- 是法式對SQL語句朋分的標識,可以自界說但必需是正文語句,不然影響SQL語句。\r\n無現實意義用於文本雅觀
5、INSERT INTO語句
/**
* 數據拔出SQL ...
*/
function sqlinsert() {
$sql='';
$tb=$this->tblist();
foreach ($tb as $v) {
$rs=mysql_query("SELECT * FROM $v");
if (!mysql_num_rows($rs)) {//有數據前往
continue;
}
$sql.="-- 表的數據:$v --\r\n";
$sql.="INSERT INTO `$v` VALUES\r\n";
while ($temp=mysql_fetch_row($rs)) {
$sql.='(';
foreach ($temp as $v2) {
if ($v2===null) {
$sql.="NULL,";
}
else {
$v2=mysql_real_escape_string($v2);
$sql.="'$v2',";
}
}
$sql=mb_substr($sql, 0, -1);
$sql.="),\r\n";
}
$sql=mb_substr($sql, 0, -3);
$sql.=";-- <xjx> --\r\n\r\n";
}
return $sql;
}
注:
1.有數據前往時必需跳出本次輪回,防止生成過剩代碼
2.當字段值為(NULL)時,拔出字符為(NULL)而不是('NULL'),沒有單引號。3.$v2=mysql_real_escape_string($v2),這是需要的本義
4.mb_substr($sql, 0, -1)、mb_substr($sql, 0, -3),必需去除最初一個逗號(,) 不然SQL語句失足5.$sql.=";-- <xjx> --\r\n\r\n",詳見第四步注
6、備份操作
/**
* 備份 ...
* @param $filename 文件途徑
*/
function beifen($filename) {
$this->db(); //銜接數據庫
$sql=$this->sqlcreate();
$sql2=$this->sqlinsert();
$data=$sql.$sql2;
return file_put_contents($filename, $data);
}
7、復原操作
/**
* 復原 ...
* @param $filename 文件途徑
*/
function huanyuan($filename) {
$this->db(); //銜接數據庫
//刪除數據表
$list=$this->tblist();
$tb='';
foreach ($list as $v) {
$tb.="`$v`,";
}
$tb=mb_substr($tb, 0, -1);
if ($tb) {
$rs=mysql_query("DROP TABLE $tb");
if ($rs===false) {
return false;
}
}
//履行SQL
$str=file_get_contents($filename);
$arr=explode('-- <xjx> --', $str);
array_pop($arr);
foreach ($arr as $v) {
$rs=mysql_query($v);
if ($rs===false) {
return false;
}
}
return true;
}
備份示例:
$x=new dbBackup();
$x->database='test';
$rs=$x->beifen('db.sql');
var_dump($rs);
復原示例:
$x=new dbBackup();
$x->database='test';
$rs=$x->huanyuan('db.sql');
var_dump($rs);
完全代碼:
class dbBackup {
public $host='localhost'; //數據庫地址
public $user='root'; //登錄名
public $pwd=''; //暗碼
public $database; //數據庫名
public $charset='utf8'; //數據庫銜接編碼:mysql_set_charset
/**
* 備份 ...
* @param $filename 文件途徑
*/
function beifen($filename) {
$this->db(); //銜接數據庫
$sql=$this->sqlcreate();
$sql2=$this->sqlinsert();
$data=$sql.$sql2;
return file_put_contents($filename, $data);
}
/**
* 復原 ...
* @param $filename 文件途徑
*/
function huanyuan($filename) {
$this->db(); //銜接數據庫
//刪除數據表
$list=$this->tblist();
$tb='';
foreach ($list as $v) {
$tb.="`$v`,";
}
$tb=mb_substr($tb, 0, -1);
if ($tb) {
$rs=mysql_query("DROP TABLE $tb");
if ($rs===false) {
return false;
}
}
//履行SQL
$str=file_get_contents($filename);
$arr=explode('-- <xjx> --', $str);
array_pop($arr);
foreach ($arr as $v) {
$rs=mysql_query($v);
if ($rs===false) {
return false;
}
}
return true;
}
/**
* 銜接數據庫 ...
*/
function db() {
$con = mysql_connect($this->host,$this->user,$this->pwd);
if (!$con){
die('Could not connect');
}
$db_selected = mysql_select_db($this->database, $con);
if (!$db_selected) {
die('Can\'t use select db');
}
mysql_set_charset($this->charset); //設置編碼
return $con;
}
/**
* 表聚集 ...
*/
function tblist() {
$list=array();
$rs=mysql_query("SHOW TABLES FROM $this->database");
while ($temp=mysql_fetch_row($rs)) {
$list[]=$temp[0];
}
return $list;
}
/**
* 表構造SQL ...
*/
function sqlcreate() {
$sql='';
$tb=$this->tblist();
foreach ($tb as $v) {
$rs=mysql_query("SHOW CREATE TABLE $v");
$temp=mysql_fetch_row($rs);
$sql.="-- 表的構造:{$temp[0]} --\r\n";
$sql.="{$temp[1]}";
$sql.=";-- <xjx> --\r\n\r\n";
}
return $sql;
}
/**
* 數據拔出SQL ...
*/
function sqlinsert() {
$sql='';
$tb=$this->tblist();
foreach ($tb as $v) {
$rs=mysql_query("SELECT * FROM $v");
if (!mysql_num_rows($rs)) {//有數據前往
continue;
}
$sql.="-- 表的數據:$v --\r\n";
$sql.="INSERT INTO `$v` VALUES\r\n";
while ($temp=mysql_fetch_row($rs)) {
$sql.='(';
foreach ($temp as $v2) {
if ($v2===null) {
$sql.="NULL,";
}
else {
$v2=mysql_real_escape_string($v2);
$sql.="'$v2',";
}
}
$sql=mb_substr($sql, 0, -1);
$sql.="),\r\n";
}
$sql=mb_substr($sql, 0, -3);
$sql.=";-- <xjx> --\r\n\r\n";
}
return $sql;
}
}
//備份
//$x=new dbBackup();
//$x->database='test';
//$rs=$x->beifen('db.sql');
//var_dump($rs);
//復原
//$x=new dbBackup();
//$x->database='test';
//$rs=$x->huanyuan('db.sql');
//var_dump($rs);