詳解MYSQL的備份還原(PHP實現(xiàn))
更新時間:2013年06月02日 20:59:58 作者:
本篇文章是對MYSQL的備份還原進行了詳細的分析介紹,需要的朋友參考下
手把手教你實現(xiàn)MYSQL的備份還原
示例代碼用我比較熟悉的PHP,當然你看完并理解了其中的思路,相信你也可以快速地用你熟悉的語言自己寫出來。
一、新建dbBackup類,設(shè)置默認參數(shù)。
class dbBackup {
public $host='localhost'; //數(shù)據(jù)庫地址
public $user='root'; //登錄名
public $pwd=''; //密碼
public $database; //數(shù)據(jù)庫名
public $charset='utf8'; //數(shù)據(jù)庫連接編碼:mysql_set_charset
}
二、添加數(shù)據(jù)庫連接function。
/**
* 連接數(shù)據(jù)庫 ...
*/
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); //設(shè)置編碼
return $con;
}
三、查詢數(shù)據(jù)庫表集合
/**
* 表集合 ...
*/
function tblist() {
$list=array();
$rs=mysql_query("SHOW TABLES FROM $this->database");
while ($temp=mysql_fetch_row($rs)) {
$list[]=$temp[0];
}
return $list;
}
四、查詢表結(jié)構(gòu)
/**
* 表結(jié)構(gòu)SQL ...
*/
function sqlcreate() {
$sql='';
$tb=$this->tblist();
foreach ($tb as $v) {
$rs=mysql_query("SHOW CREATE TABLE $v");
$temp=mysql_fetch_row($rs);
$sql.="-- 表的結(jié)構(gòu):{$temp[0]} --\r\n";
$sql.="{$temp[1]}";
$sql.=";-- <xjx> --\r\n\r\n";
}
return $sql;
}
注:$sql.=";-- <xjx> --\r\n\r\n"; 每句SQL后面必須加上分號(;)分割,MYSQL導(dǎo)入才能識別。-- <xjx> -- 是程序?qū)QL語句分割的標識,可以自定義但必須是注釋語句,否則影響SQL語句。\r\n無實際意義用于文本美觀
五、INSERT INTO語句
/**
* 數(shù)據(jù)插入SQL ...
*/
function sqlinsert() {
$sql='';
$tb=$this->tblist();
foreach ($tb as $v) {
$rs=mysql_query("SELECT * FROM $v");
if (!mysql_num_rows($rs)) {//無數(shù)據(jù)返回
continue;
}
$sql.="-- 表的數(shù)據(jù):$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.無數(shù)據(jù)返回時必須跳出本次循環(huán),避免生成多余代碼
2.當字段值為(NULL)時,插入字符為(NULL)而不是('NULL'),沒有單引號。3.$v2=mysql_real_escape_string($v2),這是必要的轉(zhuǎn)義
4.mb_substr($sql, 0, -1)、mb_substr($sql, 0, -3),必須去除最后一個逗號(,) 否則SQL語句出錯5.$sql.=";-- <xjx> --\r\n\r\n",詳見第四步注
六、備份操作
/**
* 備份 ...
* @param $filename 文件路徑
*/
function beifen($filename) {
$this->db(); //連接數(shù)據(jù)庫
$sql=$this->sqlcreate();
$sql2=$this->sqlinsert();
$data=$sql.$sql2;
return file_put_contents($filename, $data);
}
七、還原操作
/**
* 還原 ...
* @param $filename 文件路徑
*/
function huanyuan($filename) {
$this->db(); //連接數(shù)據(jù)庫
//刪除數(shù)據(jù)表
$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;
}
}
//執(zhí)行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'; //數(shù)據(jù)庫地址
public $user='root'; //登錄名
public $pwd=''; //密碼
public $database; //數(shù)據(jù)庫名
public $charset='utf8'; //數(shù)據(jù)庫連接編碼:mysql_set_charset
/**
* 備份 ...
* @param $filename 文件路徑
*/
function beifen($filename) {
$this->db(); //連接數(shù)據(jù)庫
$sql=$this->sqlcreate();
$sql2=$this->sqlinsert();
$data=$sql.$sql2;
return file_put_contents($filename, $data);
}
/**
* 還原 ...
* @param $filename 文件路徑
*/
function huanyuan($filename) {
$this->db(); //連接數(shù)據(jù)庫
//刪除數(shù)據(jù)表
$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;
}
}
//執(zhí)行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;
}
/**
* 連接數(shù)據(jù)庫 ...
*/
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); //設(shè)置編碼
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;
}
/**
* 表結(jié)構(gòu)SQL ...
*/
function sqlcreate() {
$sql='';
$tb=$this->tblist();
foreach ($tb as $v) {
$rs=mysql_query("SHOW CREATE TABLE $v");
$temp=mysql_fetch_row($rs);
$sql.="-- 表的結(jié)構(gòu):{$temp[0]} --\r\n";
$sql.="{$temp[1]}";
$sql.=";-- <xjx> --\r\n\r\n";
}
return $sql;
}
/**
* 數(shù)據(jù)插入SQL ...
*/
function sqlinsert() {
$sql='';
$tb=$this->tblist();
foreach ($tb as $v) {
$rs=mysql_query("SELECT * FROM $v");
if (!mysql_num_rows($rs)) {//無數(shù)據(jù)返回
continue;
}
$sql.="-- 表的數(shù)據(jù):$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);
示例代碼用我比較熟悉的PHP,當然你看完并理解了其中的思路,相信你也可以快速地用你熟悉的語言自己寫出來。
一、新建dbBackup類,設(shè)置默認參數(shù)。
復(fù)制代碼 代碼如下:
class dbBackup {
public $host='localhost'; //數(shù)據(jù)庫地址
public $user='root'; //登錄名
public $pwd=''; //密碼
public $database; //數(shù)據(jù)庫名
public $charset='utf8'; //數(shù)據(jù)庫連接編碼:mysql_set_charset
}
二、添加數(shù)據(jù)庫連接function。
復(fù)制代碼 代碼如下:
/**
* 連接數(shù)據(jù)庫 ...
*/
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); //設(shè)置編碼
return $con;
}
三、查詢數(shù)據(jù)庫表集合
復(fù)制代碼 代碼如下:
/**
* 表集合 ...
*/
function tblist() {
$list=array();
$rs=mysql_query("SHOW TABLES FROM $this->database");
while ($temp=mysql_fetch_row($rs)) {
$list[]=$temp[0];
}
return $list;
}
四、查詢表結(jié)構(gòu)
復(fù)制代碼 代碼如下:
/**
* 表結(jié)構(gòu)SQL ...
*/
function sqlcreate() {
$sql='';
$tb=$this->tblist();
foreach ($tb as $v) {
$rs=mysql_query("SHOW CREATE TABLE $v");
$temp=mysql_fetch_row($rs);
$sql.="-- 表的結(jié)構(gòu):{$temp[0]} --\r\n";
$sql.="{$temp[1]}";
$sql.=";-- <xjx> --\r\n\r\n";
}
return $sql;
}
注:$sql.=";-- <xjx> --\r\n\r\n"; 每句SQL后面必須加上分號(;)分割,MYSQL導(dǎo)入才能識別。-- <xjx> -- 是程序?qū)QL語句分割的標識,可以自定義但必須是注釋語句,否則影響SQL語句。\r\n無實際意義用于文本美觀
五、INSERT INTO語句
復(fù)制代碼 代碼如下:
/**
* 數(shù)據(jù)插入SQL ...
*/
function sqlinsert() {
$sql='';
$tb=$this->tblist();
foreach ($tb as $v) {
$rs=mysql_query("SELECT * FROM $v");
if (!mysql_num_rows($rs)) {//無數(shù)據(jù)返回
continue;
}
$sql.="-- 表的數(shù)據(jù):$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.無數(shù)據(jù)返回時必須跳出本次循環(huán),避免生成多余代碼
2.當字段值為(NULL)時,插入字符為(NULL)而不是('NULL'),沒有單引號。3.$v2=mysql_real_escape_string($v2),這是必要的轉(zhuǎn)義
4.mb_substr($sql, 0, -1)、mb_substr($sql, 0, -3),必須去除最后一個逗號(,) 否則SQL語句出錯5.$sql.=";-- <xjx> --\r\n\r\n",詳見第四步注
六、備份操作
復(fù)制代碼 代碼如下:
/**
* 備份 ...
* @param $filename 文件路徑
*/
function beifen($filename) {
$this->db(); //連接數(shù)據(jù)庫
$sql=$this->sqlcreate();
$sql2=$this->sqlinsert();
$data=$sql.$sql2;
return file_put_contents($filename, $data);
}
七、還原操作
復(fù)制代碼 代碼如下:
/**
* 還原 ...
* @param $filename 文件路徑
*/
function huanyuan($filename) {
$this->db(); //連接數(shù)據(jù)庫
//刪除數(shù)據(jù)表
$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;
}
}
//執(zhí)行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;
}
備份示例:
復(fù)制代碼 代碼如下:
$x=new dbBackup();
$x->database='test';
$rs=$x->beifen('db.sql');
var_dump($rs);
還原示例:
復(fù)制代碼 代碼如下:
$x=new dbBackup();
$x->database='test';
$rs=$x->huanyuan('db.sql');
var_dump($rs);
完整代碼:
復(fù)制代碼 代碼如下:
class dbBackup {
public $host='localhost'; //數(shù)據(jù)庫地址
public $user='root'; //登錄名
public $pwd=''; //密碼
public $database; //數(shù)據(jù)庫名
public $charset='utf8'; //數(shù)據(jù)庫連接編碼:mysql_set_charset
/**
* 備份 ...
* @param $filename 文件路徑
*/
function beifen($filename) {
$this->db(); //連接數(shù)據(jù)庫
$sql=$this->sqlcreate();
$sql2=$this->sqlinsert();
$data=$sql.$sql2;
return file_put_contents($filename, $data);
}
/**
* 還原 ...
* @param $filename 文件路徑
*/
function huanyuan($filename) {
$this->db(); //連接數(shù)據(jù)庫
//刪除數(shù)據(jù)表
$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;
}
}
//執(zhí)行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;
}
/**
* 連接數(shù)據(jù)庫 ...
*/
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); //設(shè)置編碼
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;
}
/**
* 表結(jié)構(gòu)SQL ...
*/
function sqlcreate() {
$sql='';
$tb=$this->tblist();
foreach ($tb as $v) {
$rs=mysql_query("SHOW CREATE TABLE $v");
$temp=mysql_fetch_row($rs);
$sql.="-- 表的結(jié)構(gòu):{$temp[0]} --\r\n";
$sql.="{$temp[1]}";
$sql.=";-- <xjx> --\r\n\r\n";
}
return $sql;
}
/**
* 數(shù)據(jù)插入SQL ...
*/
function sqlinsert() {
$sql='';
$tb=$this->tblist();
foreach ($tb as $v) {
$rs=mysql_query("SELECT * FROM $v");
if (!mysql_num_rows($rs)) {//無數(shù)據(jù)返回
continue;
}
$sql.="-- 表的數(shù)據(jù):$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);
您可能感興趣的文章:
- mysqldump備份還原和mysqldump導(dǎo)入導(dǎo)出語句大全詳解
- PHP備份/還原MySQL數(shù)據(jù)庫的代碼
- mysql 數(shù)據(jù)庫備份和還原方法集錦 推薦
- MySQL數(shù)據(jù)庫備份和還原的常用命令小結(jié)
- MySQL中使用innobackupex、xtrabackup進行大數(shù)據(jù)的備份和還原教程
- MySQL使用命令備份和還原數(shù)據(jù)庫
- 命令行模式下備份、還原 MySQL 數(shù)據(jù)庫的語句小結(jié)
- 深入解析Linux下MySQL數(shù)據(jù)庫的備份與還原
- MySQL數(shù)據(jù)庫如何導(dǎo)入導(dǎo)出(備份還原)
- 史上最簡單的MySQL數(shù)據(jù)備份與還原教程(上)(三十五)
相關(guān)文章
mysql運行net start mysql報服務(wù)名無效的解決辦法
這篇文章主要為大家詳細介紹了mysql運行net start mysql報服務(wù)名無效的解決辦法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-01-01mysql實現(xiàn)將字符串字段轉(zhuǎn)為數(shù)字排序或比大小
這篇文章主要介紹了mysql實現(xiàn)將字符串字段轉(zhuǎn)為數(shù)字排序或比大小,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-06-06在Hadoop集群環(huán)境中為MySQL安裝配置Sqoop的教程
這篇文章主要介紹了在Hadoop集群環(huán)境中為MySQL安裝配置Sqoop的教程,Sqoop一般被用于數(shù)據(jù)庫軟件之間的數(shù)據(jù)遷移,需要的朋友可以參考下2015-12-12關(guān)于MySQL中datetime和timestamp的區(qū)別解析
在MySQL中一些日期字段的類型選擇為datetime和timestamp,那么對于這兩種類型不同的應(yīng)用場景是什么呢,這篇文章主要介紹了關(guān)于MySQL中datetime和timestamp的區(qū)別解析,需要的朋友可以參考下2023-06-06mysql設(shè)置遠程訪問數(shù)據(jù)庫的多種方法
最近有一同學(xué)問我MySQL無法遠程訪問怎么呢,但能使用localhost來進行方法,下面腳本之家來給各位介紹一下解決辦法,需要的朋友可以參考下2013-10-10