php進行資料備份與還原
阿新 • • 發佈:2019-01-25
<pre name="code" class="php"><?php 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); ?>