亚洲免费不卡_在线视频精品_国产尤物精品_久久久久网址_久久精品91_欧美va天堂在线_狠狠入ady亚洲精品_亚洲午夜精品福利_国产精品草草_午夜精品久久99蜜桃的功能介绍

php數據庫備份還原類分享
來源:易賢網 閱讀:1497 次 日期:2014-08-22 10:01:37
溫馨提示:易賢網小編為您整理了“php數據庫備份還原類分享”,方便廣大網友查閱!

這篇文章主要介紹了php數據庫備份還原類,需要的朋友可以參考下

代碼如下:

<?php

/**

* 數據庫備份還原類

* @author xialeistudio<admin@xialeistudio.net>

* Class DatabaseTool

*/

class DatabaseTool

{

private $handler;

private $config = array(

'host' => 'localhost',

'port' => 3306,

'user' => 'root',

'password' => '',

'database' => 'test',

'charset' => 'utf-8',

'target' => 'sql.sql'

);

private $tables = array();

private $error;

private $begin; //開始時間

/**

* 架構方法

* @param array $config

*/

public function __construct($config = array())

{

$this->begin = microtime(true);

$config = is_array($config) ? $config : array();

$this->config = array_merge($this->config, $config);

//啟動PDO連接

if (!$this->handler instanceof PDO)

{

try

{

$this->handler = new PDO("mysql:host={$this->config['host']}:{$this->config['port']};dbname={$this->config['database']}", $this->config['user'], $this->config['password']);

}

catch (PDOException $e)

{

$this->error = $e->getMessage();

return false;

}

catch (Exception $e)

{

$this->error = $e->getMessage();

return false;

}

}

}

/**

* 備份

* @param array $tables

* @return bool

*/

public function backup($tables = array())

{

//存儲表定義語句的數組

$ddl = array();

//存儲數據的數組

$data = array();

$this->setTables($tables);

if (!empty($this->tables))

{

foreach ($this->tables as $table)

{

$ddl[] = $this->getDDL($table);

$data[] = $this->getData($table);

}

//開始寫入

$this->writeToFile($this->tables, $ddl, $data);

}

else

{

$this->error = '數據庫中沒有表!';

return false;

}

}

/**

* 設置要備份的表

* @param array $tables

*/

private function setTables($tables = array())

{

if (!empty($tables) && is_array($tables))

{

//備份指定表

$this->tables = $tables;

}

else

{

//備份全部表

$this->tables = $this->getTables();

}

}

/**

* 查詢

* @param string $sql

* @return mixed

*/

private function query($sql = '')

{

$stmt = $this->handler->query($sql);

$stmt->setFetchMode(PDO::FETCH_NUM);

$list = $stmt->fetchAll();

return $list;

}

/**

* 獲取全部表

* @return array

*/

private function getTables()

{

$sql = 'SHOW TABLES';

$list = $this->query($sql);

$tables = array();

foreach ($list as $value)

{

$tables[] = $value[0];

}

return $tables;

}

/**

* 獲取表定義語句

* @param string $table

* @return mixed

*/

private function getDDL($table = '')

{

$sql = "SHOW CREATE TABLE `{$table}`";

$ddl = $this->query($sql)[0][1] . ';';

return $ddl;

}

/**

* 獲取表數據

* @param string $table

* @return mixed

*/

private function getData($table = '')

{

$sql = "SHOW COLUMNS FROM `{$table}`";

$list = $this->query($sql);

//字段

$columns = '';

//需要返回的SQL

$query = '';

foreach ($list as $value)

{

$columns .= "`{$value[0]}`,";

}

$columns = substr($columns, 0, -1);

$data = $this->query("SELECT * FROM `{$table}`");

foreach ($data as $value)

{

$dataSql = '';

foreach ($value as $v)

{

$dataSql .= "'{$v}',";

}

$dataSql = substr($dataSql, 0, -1);

$query .= "INSERT INTO `{$table}` ({$columns}) VALUES ({$dataSql});rn";

}

return $query;

}

/**

* 寫入文件

* @param array $tables

* @param array $ddl

* @param array $data

*/

private function writeToFile($tables = array(), $ddl = array(), $data = array())

{

$str = "/*rnMySQL Database Backup Toolsrn";

$str .= "Server:{$this->config['host']}:{$this->config['port']}rn";

$str .= "Database:{$this->config['database']}rn";

$str .= "Data:" . date('Y-m-d H:i:s', time()) . "rn*/rn";

$str .= "SET FOREIGN_KEY_CHECKS=0;rn";

$i = 0;

foreach ($tables as $table)

{

$str .= "-- ----------------------------rn";

$str .= "-- Table structure for {$table}rn";

$str .= "-- ----------------------------rn";

$str .= "DROP TABLE IF EXISTS `{$table}`;rn";

$str .= $ddl[$i] . "rn";

$str .= "-- ----------------------------rn";

$str .= "-- Records of {$table}rn";

$str .= "-- ----------------------------rn";

$str .= $data[$i] . "rn";

$i++;

}

echo file_put_contents($this->config['target'], $str) ? '備份成功!花費時間' . (microtime(true) - $this->begin) . 'ms' : '備份失敗!';

}

/**

* 錯誤信息

* @return mixed

*/

public function getError()

{

return $this->error;

}

public function restore($path = '')

{

if (!file_exists($path))

{

$this->error('SQL文件不存在!');

return false;

}

else

{

$sql = $this->parseSQL($path);

try

{

$this->handler->exec($sql);

echo '還原成功!花費時間', (microtime(true) - $this->begin) . 'ms';

}

catch (PDOException $e)

{

$this->error = $e->getMessage();

return false;

}

}

}

/**

* 解析SQL文件為SQL語句數組

* @param string $path

* @return array|mixed|string

*/

private function parseSQL($path = '')

{

$sql = file_get_contents($path);

$sql = explode("rn", $sql);

//先消除--注釋

$sql = array_filter($sql, function ($data)

{

if (empty($data) || preg_match('/^--.*/', $data))

{

return false;

}

else

{

return true;

}

});

$sql = implode('', $sql);

//刪除/**/注釋

$sql = preg_replace('//*.**//', '', $sql);

return $sql;

}

}

更多信息請查看IT技術專欄

更多信息請查看網絡編程
易賢網手機網站地址:php數據庫備份還原類分享
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點

版權所有:易賢網

亚洲免费不卡_在线视频精品_国产尤物精品_久久久久网址_久久精品91_欧美va天堂在线_狠狠入ady亚洲精品_亚洲午夜精品福利_国产精品草草_午夜精品久久99蜜桃的功能介绍
亚洲一区二区三区午夜| 国产日韩欧美一区二区| 欧美日韩国产探花| 国内外成人免费视频| 亚洲欧洲精品一区| 麻豆九一精品爱看视频在线观看免费| 久久综合伊人| 亚洲巨乳在线| 久久综合狠狠综合久久综青草| 欧美日韩一区二区三区四区在线观看| 亚洲小说欧美另类社区| 国产视频在线观看一区| 久久成人一区| 亚洲国产婷婷| 欧美一区二区三区在线播放| 今天的高清视频免费播放成人| 亚洲一区二区免费看| 国产精品黄色| 女女同性女同一区二区三区91| 亚洲精品影院在线观看| 午夜精品婷婷| 久久久精品网| 一区二区福利| 亚洲欧洲精品一区二区| 欧美日韩在线高清| 久久久久综合| 亚洲欧美日韩在线综合| 国产欧美不卡| 亚洲第一黄网| 在线播放精品| 亚洲福利国产| 在线成人av| 国产在线日韩| 国产在线不卡| 精品白丝av| 黄色另类av| 影音先锋亚洲精品| 亚洲国产婷婷| 亚洲精品孕妇| 国产婷婷精品| 国产欧美亚洲一区| 国产日韩1区| 国产亚洲一级| 亚洲欧美日韩视频二区| 免费一区二区三区| 久久亚洲高清| 欧美精品自拍| 影音先锋国产精品| 国产日韩精品久久| 久久精品电影| 欧美日韩一区二区三区免费| 欧美性久久久| 影音先锋中文字幕一区| 在线综合视频| 欧美一区二区三区四区在线观看地址 | 国产一区视频观看| 国产精品vip| 亚洲一级电影| 亚洲美女少妇无套啪啪呻吟| 99综合在线| 欧美亚洲三区| 欧美国产三级| 精品动漫av| 先锋影音久久久| 欧美日韩第一区| 91久久国产综合久久蜜月精品| 亚洲伦理精品| 久久国产精品亚洲va麻豆| 欧美日韩一区在线播放| 99在线|亚洲一区二区| 麻豆精品网站| 亚洲国产影院| 欧美阿v一级看视频| 一区三区视频| 久久综合九色综合网站| 樱桃成人精品视频在线播放| 午夜在线观看免费一区| 激情综合电影网| 欧美亚洲一区二区三区| 伊人久久综合| 欧美激情91| 亚洲一区二区三区四区中文| 国内精品久久久久久久影视蜜臀 | 女人色偷偷aa久久天堂| 亚洲精品在线免费| 欧美国内亚洲| 亚洲一区二区三区色| 欧美日本韩国在线| 亚洲专区在线| 99av国产精品欲麻豆| 午夜日韩视频| 久久久久久色| 亚洲欧美精品在线观看| 日韩一级不卡| 亚洲高清自拍| 欧美日韩亚洲一区二区三区在线| 国产女主播一区二区| 一区在线播放| 欧美日韩一区在线视频| 欧美专区一区二区三区| 亚洲视频1区| 亚洲人成人一区二区三区| 欧美日韩蜜桃| 欧美激情一级片一区二区| 国产伦精品一区二区三区视频黑人 | 欧美日本国产| 欧美一区激情| 久久综合影音| 久久男女视频| 午夜精品视频在线观看一区二区| 美女精品一区| 先锋影音一区二区三区| 亚洲一区二区精品在线| 国产精品日韩精品欧美精品| 一本色道久久综合亚洲精品高清| 亚洲精品欧洲| 一区二区三区四区五区精品| 999亚洲国产精| 一区二区三区三区在线| 国产精品一区视频网站| 国产精品日韩欧美一区二区| 国产精品夜夜夜一区二区三区尤| 99精品国产福利在线观看免费| 亚洲精品在线观看免费| 国产精品日韩| 欧美一区二区三区四区夜夜大片| 欧美福利精品| 在线播放一区| 亚洲欧美日韩精品一区二区| 久久久久久久波多野高潮日日| 麻豆成人在线播放| 欧美日本一区| 亚洲精品国产日韩| 午夜在线一区二区| 午夜精品一区二区在线观看 | 免费亚洲网站| 午夜欧美视频| 在线观看日韩av电影| 亚洲免费成人| 久久综合导航| 亚洲欧洲一区二区天堂久久| 亚洲欧美大片| 国产精品高清一区二区三区| 99精品99| 欧美日韩一区二区三区四区在线观看| 好吊色欧美一区二区三区视频| 影音先锋一区| 免播放器亚洲| 欧美视频网站| 国产美女一区| 极品日韩久久| 美日韩精品免费| 亚洲人www| 欧美久色视频| 亚洲免费影院| 亚洲国产免费看| 欧美国产免费| 亚洲一区二区三区高清不卡| 欧美视频二区| 久久高清国产| 一区二区三区久久网| 欧美人成网站| 久久精品一区二区三区中文字幕| 国内在线观看一区二区三区| 另类国产ts人妖高潮视频| 亚洲东热激情| 狠狠88综合久久久久综合网| 麻豆av一区二区三区| av不卡免费看| 亚洲午夜久久久久久尤物| 久久香蕉精品| 久久av在线| 国产精品视频免费观看| 亚洲国产精品一区二区第一页| 久久亚洲精品欧美| 亚洲欧美日韩国产一区二区| 一本久久知道综合久久| 亚洲欧洲精品一区| 亚洲高清久久| 亚洲国产婷婷| 亚洲伦伦在线| 国产视频在线观看一区| 国产日韩欧美精品| 亚洲免费综合| 久久久国产精品一区二区中文| 亚洲一区在线免费| 国产亚洲精品v| 一本色道久久综合亚洲精品高清| 在线观看欧美亚洲| 亚洲精品男同| 国产精品视区| 久久精品中文| 欧美 日韩 国产一区二区在线视频| 久久99伊人| 欧美日本三区| 亚洲人久久久| 国产偷自视频区视频一区二区| 国产精品区二区三区日本| 国产精品久久久久久久久久妞妞| 国产精品久久久久9999高清| 亚洲欧美久久久| 欧美一区二区视频在线| 欧美特黄视频| 日韩视频在线观看国产| 国产精品免费看| 久久久久久精| 亚洲无玛一区| 国产一区二区三区黄| 先锋亚洲精品| 欧美午夜精品| 中文欧美日韩| 可以看av的网站久久看| 欧美午夜免费| 国产亚洲欧美另类一区二区三区| 久久久精品五月天| 影音先锋亚洲精品| 亚洲一区二区三区涩| 欧美国产视频在线观看| 亚洲视频碰碰| 欧美专区18| 亚洲成人自拍视频| 久久国产精品99国产| 午夜日韩电影| 亚洲专区欧美专区| 激情欧美日韩一区| 久久黄色影院| 亚洲激情av| 另类av一区二区| 亚洲福利国产| 老司机午夜精品视频| 精品av久久久久电影| 西西裸体人体做爰大胆久久久| 亚洲视频狠狠| 午夜国产一区| 亚洲男人影院| 亚洲日本激情| 国产精品大片| 午夜精品免费| 欧美综合国产| 国产精品人人爽人人做我的可爱| 国产一区二区在线观看免费播放| 国产精品有限公司| 亚洲精品一品区二品区三品区| 欧美成人一品| 亚洲一区亚洲| 国产精品美女| 日韩视频三区| 亚洲婷婷免费| 国产精品a级| 午夜精彩国产免费不卡不顿大片| 中日韩男男gay无套| 影音先锋国产精品| 亚洲视频精品| 欧美精品国产一区二区| 久久av一区二区三区| 国产精品日韩精品欧美精品| 一本色道久久综合亚洲精品不| 国产精品v欧美精品v日本精品动漫| 国产伦精品一区二区三区四区免费| 影音先锋久久精品| 亚洲激情欧美| 亚洲日产国产精品| 亚洲国产影院| 亚洲精品韩国| 99成人在线| 99视频精品| 国产日韩精品久久| 午夜亚洲一区| 久久久久网站| 欧美淫片网站| 欧美日韩综合| 在线观看欧美一区| 亚洲国产一区二区精品专区| 影音先锋久久| 在线亚洲国产精品网站| 国产一区二区高清视频| 国产日韩欧美高清免费| 亚洲一区三区电影在线观看| 美女黄网久久| 欧美先锋影音| 亚洲精品影视| 欧美一级专区| 欧美日韩专区| 亚洲精品在线视频观看| 中日韩男男gay无套| 香蕉国产精品偷在线观看不卡| 久久久精品性| 欧美日韩天堂| 日韩亚洲精品在线| 久久久国产亚洲精品| 欧美性久久久| 国产日韩在线一区二区三区| 久久亚洲影院| 亚洲国产日韩在线| 国产精品制服诱惑| 欧美精品麻豆| 一区二区三区精品国产| 久久日韩精品| 亚洲麻豆av| 久久天天狠狠| 一区二区三区欧美在线| 欧美在线影院| 一区二区动漫| 国产中文一区二区| 亚洲色图自拍| 欧美精品入口| 香蕉久久国产| 亚洲欧洲日夜超级视频| 欧美1区免费| 国产欧美日本在线| 欧美日韩一区二区三区在线观看免 | 国产精品毛片va一区二区三区| 久久综合伊人| 在线一区日本视频| 国产精品激情| 香蕉久久夜色精品| 尹人成人综合网| 欧美日韩午夜| 久久成人在线| 在线亚洲欧美| 99国产精品久久久久久久成人热| 午夜精品久久99蜜桃的功能介绍| 国产一区二区三区的电影| 亚洲成人在线视频网站| 欧美大香线蕉线伊人久久国产精品| 一本色道婷婷久久欧美| 尹人成人综合网| 狠狠干综合网| 欧美日韩精品免费观看视频完整| 亚洲一区欧美激情| 国产一区二区久久久| 亚洲精品影院在线观看| 精品动漫3d一区二区三区免费| 欧美精品一区二区视频| 久久性天堂网| 久久午夜精品| 久久久久se| 久久精品一区二区国产| 麻豆久久婷婷| 欧美一区二区三区在线播放| 亚洲一区自拍| 欧美一区=区| 久久免费国产| 欧美成人综合| 欧美午夜一区二区福利视频| 欧美日韩一区二区国产| 欧美日韩一区二区三区在线观看免 | 六月天综合网| 亚洲综合三区| 久久精品国产第一区二区三区最新章节| 一本色道久久综合| 一区二区日本视频| 国产一区二区精品| 国产精品一区视频| 亚洲一区二区在线免费观看| 欧美亚洲专区| 狂野欧美性猛交xxxx巴西| 欧美一区二区| 欧美日本一区二区高清播放视频| 久久久久综合一区二区三区| 久久狠狠一本精品综合网| 99国产精品| 国产精品免费在线| 欧美中文日韩| 欧美日韩亚洲国产精品| 亚洲国产导航| 午夜在线一区二区| 欧美视频日韩| 亚洲精品男同| 蜜桃久久av| 在线国产精品一区| 日韩视频二区| 久久综合伊人| 亚洲国产一区二区在线| 国产欧美日本在线| 欧美在线网站| 日韩一级免费| 你懂的国产精品| 亚洲精品日本| 欧美一区亚洲| 亚洲经典视频在线观看| 久久国产免费| 夜夜嗨一区二区| 欧美激情综合| 亚洲资源av| 91久久精品一区二区别| 久久久久久9| 国产日韩亚洲欧美精品| 欧美三级网页| 国产精品一卡| 亚洲高清资源| 久久中文在线| 国产欧美亚洲一区| 亚洲午夜精品久久久久久app| 国产精品一区二区a| 在线视频观看日韩| 欧美日韩在线精品| 久久久久99| 亚洲欧美电影在线观看| 亚洲高清免费|