詳解MYSQL的備份還原(PHP實(shí)現(xiàn))_MySQL教程
推薦:基于mysql全文索引的深入理解本篇文章是對(duì)mysql全文索引進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
手把手教你實(shí)現(xiàn)MYSQL的備份還原示例代碼用我比較熟悉的PHP,當(dāng)然你看完并理解了其中的思路,相信你也可以快速地用你熟悉的語(yǔ)言自己寫(xiě)出來(lái)。
一、新建dbBackup類(lèi),設(shè)置默認(rèn)參數(shù)。
復(fù)制代碼 代碼如下:www.hl5o.cn
class dbBackup {
public $host='localhost'; //數(shù)據(jù)庫(kù)地址
public $user='root'; //登錄名
public $pwd=''; //密碼
public $database; //數(shù)據(jù)庫(kù)名
public $charset='utf8'; //數(shù)據(jù)庫(kù)連接編碼:mysql_set_charset
}
二、添加數(shù)據(jù)庫(kù)連接function。
復(fù)制代碼 代碼如下:www.hl5o.cn
/**
* 連接數(shù)據(jù)庫(kù) ...
*/
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ù)庫(kù)表集合
復(fù)制代碼 代碼如下:www.hl5o.cn
/**
* 表集合 ...
*/
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ù)制代碼 代碼如下:www.hl5o.cn
/**
* 表結(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后面必須加上分號(hào)(;)分割,MYSQL導(dǎo)入才能識(shí)別。-- <xjx> -- 是程序?qū)QL語(yǔ)句分割的標(biāo)識(shí),可以自定義但必須是注釋語(yǔ)句,否則影響SQL語(yǔ)句。\r\n無(wú)實(shí)際意義用于文本美觀
五、INSERT INTO語(yǔ)句
復(fù)制代碼 代碼如下:www.hl5o.cn
/**
* 數(shù)據(jù)插入SQL ...
*/
function sqlinsert() {
$sql='';
$tb=$this->tblist();
foreach ($tb as $v) {
$rs=mysql_query("SELECT * FROM $v");
if (!mysql_num_rows($rs)) {//無(wú)數(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.無(wú)數(shù)據(jù)返回時(shí)必須跳出本次循環(huán),避免生成多余代碼
2.當(dāng)字段值為(NULL)時(shí),插入字符為(NULL)而不是('NULL'),沒(méi)有單引號(hào)。3.$v2=mysql_real_escape_string($v2),這是必要的轉(zhuǎn)義
4.mb_substr($sql, 0, -1)、mb_substr($sql, 0, -3),必須去除最后一個(gè)逗號(hào)(,) 否則SQL語(yǔ)句出錯(cuò)5.$sql.=";-- <xjx> --\r\n\r\n",詳見(jiàn)第四步注
六、備份操作
復(fù)制代碼 代碼如下:www.hl5o.cn
/**
* 備份 ...
* @param $filename 文件路徑
*/
function beifen($filename) {
$this->db(); //連接數(shù)據(jù)庫(kù)
$sql=$this->sqlcreate();
$sql2=$this->sqlinsert();
$data=$sql.$sql2;
return file_put_contents($filename, $data);
}
七、還原操作
復(fù)制代碼 代碼如下:www.hl5o.cn
/**
* 還原 ...
* @param $filename 文件路徑
*/
function huanyuan($filename) {
$this->db(); //連接數(shù)據(jù)庫(kù)
//刪除數(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ù)制代碼 代碼如下:www.hl5o.cn
$x=new dbBackup();
$x->database='test';
$rs=$x->beifen('db.sql');
var_dump($rs);
還原示例:
復(fù)制代碼 代碼如下:www.hl5o.cn
$x=new dbBackup();
$x->database='test';
$rs=$x->huanyuan('db.sql');
var_dump($rs);
完整代碼:
復(fù)制代碼 代碼如下:www.hl5o.cn
class dbBackup {
public $host='localhost'; //數(shù)據(jù)庫(kù)地址
public $user='root'; //登錄名
public $pwd=''; //密碼
public $database; //數(shù)據(jù)庫(kù)名
public $charset='utf8'; //數(shù)據(jù)庫(kù)連接編碼:mysql_set_charset
/**
* 備份 ...
* @param $filename 文件路徑
*/
function beifen($filename) {
$this->db(); //連接數(shù)據(jù)庫(kù)
$sql=$this->sqlcreate();
$sql2=$this->sqlinsert();
$data=$sql.$sql2;
return file_put_contents($filename, $data);
}
/**
* 還原 ...
* @param $filename 文件路徑
*/
function huanyuan($filename) {
$this->db(); //連接數(shù)據(jù)庫(kù)
//刪除數(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ù)庫(kù) ...
*/
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)) {//無(wú)數(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);
分享:10大關(guān)系數(shù)據(jù)庫(kù)SQL注入工具一覽BSQL Hacker BSQL Hacker是由Portcullis實(shí)驗(yàn)室開(kāi)發(fā)的,BSQL Hacker 是一個(gè)SQL自動(dòng)注入工具(支持SQL盲注),其設(shè)計(jì)的目的是希望能對(duì)任何的數(shù)據(jù)庫(kù)進(jìn)行SQL溢出注入。 BSQL Hacker的適用群體是那些對(duì)注入有經(jīng)驗(yàn)的使用者和那些想進(jìn)行自動(dòng)SQL注入的人群。BSQL Hacker可自動(dòng)對(duì)O
相關(guān)MySQL教程:
- MSSQL清空日志刪除日志文件
- 關(guān)于數(shù)據(jù)庫(kù)中保留小數(shù)位的問(wèn)題
- 解析mysql與Oracle update的區(qū)別
- mysql 導(dǎo)入導(dǎo)出數(shù)據(jù)庫(kù)以及函數(shù)、存儲(chǔ)過(guò)程的介紹
- MySQL——修改root密碼的4種方法(以windows為例)
- 解決MYSQL出現(xiàn)Can''t create/write to file ''#sql_5c0_0.MYD''的問(wèn)題
- 深入理解SQL的四種連接-左外連接、右外連接、內(nèi)連接、全連接
- 解析:內(nèi)聯(lián),左外聯(lián),右外聯(lián),全連接,交叉連接的區(qū)別
- mysql出現(xiàn)“Incorrect key file for table”處理方法
- mysql重裝后出現(xiàn)亂碼設(shè)置為utf8可解決
- 淺析一個(gè)MYSQL語(yǔ)法(在查詢中使用count)的兼容性問(wèn)題
- 解析MySQL中INSERT INTO SELECT的使用
MySQL教程Rss訂閱編程教程搜索
MySQL教程推薦
- Mysql select in 按id排序?qū)崿F(xiàn)方法
- 深入mysql "ON DUPLICATE KEY UPDATE" 語(yǔ)法的分析
- Mysql中的find_in_set的使用方法介紹
- mysql創(chuàng)建函數(shù)出現(xiàn)1418錯(cuò)誤的解決辦法
- 在SQL Server的try...catch語(yǔ)句中獲取錯(cuò)誤消息代碼的的語(yǔ)句
- MySQL 5.6 如何更改安全的處理密碼探討
- MySQL的重裝問(wèn)題解決方法
- Mysql DNS反向解析導(dǎo)致連接超時(shí)過(guò)程分析(skip-name-resolve)
- SQL查詢超時(shí)的設(shè)置方法(關(guān)于timeout的處理)
- JDBC數(shù)據(jù)庫(kù)的使用操作總結(jié)
猜你也喜歡看這些
- MySQL的數(shù)據(jù)類(lèi)型和建庫(kù)策略
- SQL Server 2005 DTS導(dǎo)入平面數(shù)據(jù)出現(xiàn)錯(cuò)誤解決方案
- SQL Server導(dǎo)出導(dǎo)入數(shù)據(jù)方法
- 巧用一條SQL語(yǔ)句實(shí)現(xiàn)其它進(jìn)制到十進(jìn)制轉(zhuǎn)換
- 解決SQLSERVER2005的混和身份驗(yàn)證模式的設(shè)置以及SA登陸問(wèn)題
- SQL Server的EXISTS結(jié)構(gòu)學(xué)習(xí)
- 淺談SQL Server 2008數(shù)據(jù)挖掘查詢?nèi)蝿?wù)
- 解析修復(fù)SQL Server的MDF文件的方法
- 如何將SQL 2000日志遷移到SQL Server 2008
- 揭秘Sql語(yǔ)句優(yōu)化注意事項(xiàng)
- 相關(guān)鏈接:
- 教程說(shuō)明:
MySQL教程-詳解MYSQL的備份還原(PHP實(shí)現(xiàn))
。