日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

tp5备份mysql_tp5备份数据库

發布時間:2025/4/5 数据库 18 豆豆
生活随笔 收集整理的這篇文章主要介紹了 tp5备份mysql_tp5备份数据库 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

/**

* 備份數據庫的擴展類

*/

class Baksql {

private $config = [];

private $handler;

private $tables = array(); //需要備份的表

private $begin; //開始時間

private $error; //錯誤信息

public function __construct($config, $uniacid) {

$fileName = ROOT_PATH . 'public' . DS . 'static' . DS . 'data/'; //默認目錄

if (!empty($uniacid)) {

$fileName .= $uniacid . '/';

}

$dir = iconv("UTF-8", "GBK", $fileName);

if (!file_exists($dir)) {

mkdir($dir, 0777, true);

}

$config['path'] = $fileName; //默認目錄

$config["sqlbakname"] = date("YmdHis", time()) . ".sql"; //默認保存文件

$this->config = $config;

$this->begin = microtime(true);

header("Content-type: text/html;charset=utf-8");

$this->connect();

}

//首次進行pdo連接

private function connect() {

try {

$this->handler = new \PDO("{$this->config['type']}:host={$this->config['hostname']};port={$this->config['hostport']};dbname={$this->config['database']};",

$this->config['username'],

$this->config['password'],

array(

\PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES {$this->config['charset']};",

\PDO::ATTR_ERRMODE => \PDO::ERRMODE_EXCEPTION,

\PDO::ATTR_DEFAULT_FETCH_MODE => \PDO::FETCH_ASSOC

));

} catch (PDOException $e) {

die("Error!: " . $e->getMessage() . "
");

}

}

/**

* 查詢

* @param string $sql

* @return mixed

*/

private function query($sql = '') {

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

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

$list = $stmt->fetchAll();

return $list;

}

/**

* 獲取全部表

* @param string $dbName

* @return array

*/

private function get_dbname($dbName = '*') {

$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 get_dbhead($table = '') {

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

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

return $ddl;

}

/**

* 獲取表數據

* @param string $table

* @return mixed

*/

private function get_dbdata($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});\r\n";

}

return $query;

}

/**

* 寫入文件

* @param array $tables

* @param array $ddl

* @param array $data

*/

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

$str = "/*\r\nMySQL Database Backup Tools\r\n";

$str .= "Server:{$this->config['hostname']}:{$this->config['hostport']}\r\n";

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

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

$str .= "SET FOREIGN_KEY_CHECKS=0;\r\n";

$i = 0;

foreach ($tables as $table) {

$str .= "-- ----------------------------\r\n";

$str .= "-- Table structure for {$table}\r\n";

$str .= "-- ----------------------------\r\n";

$str .= "DROP TABLE IF EXISTS `{$table}`;\r\n";

$str .= $ddl[$i] . "\r\n";

$str .= "-- ----------------------------\r\n";

$str .= "-- Records of {$table}\r\n";

$str .= "-- ----------------------------\r\n";

$str .= $data[$i] . "\r\n";

$i++;

}

if (!file_exists($this->config['path'])) {

mkdir($this->config['path']);

}

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

}

/**

* 設置要備份的表

* @param array $tables

*/

private function setTables($tables = array()) {

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

//備份指定表

$this->tables = $tables;

} else {

//備份全部表

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

}

}

/**

* 備份

* @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->get_dbhead($table);

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

}

//開始寫入

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

} else {

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

return false;

}

}

/**

* 錯誤信息

* @return mixed

*/

public function getError() {

return $this->error;

}

public function restore($filename = '') {

$path = $this->config['path'] . $filename;

if (!file_exists($path)) {

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

return false;

} else {

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

//dump($sql);die;

try {

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

echo '還原成功!花費時間', round(microtime(true) - $this->begin, 2) . '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("\r\n", $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;

}

/**

* 下載備份

* @param string $fileName

* @return array|mixed|string

*/

public function downloadFile($fileName) {

$fileName = $this->config['path'] . $fileName;

if (file_exists($fileName)) {

ob_end_clean();

header("Cache-Control: must-revalidate, post-check=0, pre-check=0");

header('Content-Description: File Transfer');

header('Content-Type: application/octet-stream');

header('Content-Length: ' . filesize($fileName));

header('Content-Disposition: attachment; filename=' . basename($fileName));

readfile($fileName);

} else {

$this->error = "文件有錯誤!";

}

}

/**

* 獲取文件是時間

* @param string $file

* @return string

*/

private function getfiletime($file) {

$path = $this->config['path'] . $file;

$a = filemtime($path);

$time = date("Y-m-d H:i:s", $a);

return $time;

}

/**

* 獲取文件是大小

* @param string $file

* @return string

*/

private function getfilesize($file) {

$perms = stat($this->config['path'] . $file);

$size = $perms['size'];

$a = ['B', 'KB', 'MB', 'GB', 'TB'];

$pos = 0;

while ($size >= 1024) {

$size /= 1024;

$pos++;

}

return round($size, 2) . $a[$pos];

}

/**

* 獲取文件列表

* @param string $Order 級別

* @return array

*/

public function get_filelist($Order = 0) {

$FilePath = $this->config['path'];

$FilePath = opendir($FilePath);

$FileAndFolderAyy = array();

$i = 1;

while (false !== ($filename = readdir($FilePath))) {

if ($filename != "." && $filename != "..") {

$i++;

$FileAndFolderAyy[$i]['name'] = $filename;

$FileAndFolderAyy[$i]['time'] = $this->getfiletime($filename);

$FileAndFolderAyy[$i]['size'] = $this->getfilesize($filename);

}

}

$Order == 0 ? sort($FileAndFolderAyy) : rsort($FileAndFolderAyy);

return $FileAndFolderAyy;

}

public function delfilename($filename) {

$path = $this->config['path'] . $filename;

if (@unlink($path)) {

return '刪除成功';

}

}

}

?>

namespace lib;

use think\Loader;

/**

* Description of Qrcode

*

* @author lsf

*/

class Backup {

private $sql;

//put your code here

public function __construct($uniacid="") {

Loader::import("baksql/Baksql", EXTEND_PATH);

$this->sql = new \Baksql(\think\Config::get("database"),$uniacid);

}

//數據庫備份

public function bak($type = "", $name = "", $table = array()) {

switch ($type) {

case "backup": //備份

$res = $this->sql->backup($table);

if ($res) {

return array("success" => true, "message" => "", "data" => $res);

} else {

return array("success" => false, "message" => $this->sql->getError());

}

case "dowonload": //下載

return $this->sql->downloadFile($name);

case "restore": //還原

$info = $this->sql->restore($name);

return array("success" => true, "data" => $info);

case "del": //刪除

return $this->sql->delfilename($name);

default: //獲取備份文件列表

return array("success" => true, "data" => $this->sql->get_filelist());

}

}

}

總結

以上是生活随笔為你收集整理的tp5备份mysql_tp5备份数据库的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 网站一级片| 另类性姿势bbwbbw | 亚洲色婷婷一区二区三区 | 中文字幕一区二区人妻电影丶 | 男人在线网站 | 亚洲色图 在线视频 | 日韩三级国产精品 | 色婷婷在线视频 | 天堂av影院 | 天堂网视频 | www.看毛片| 爽爽免费视频 | 国产美女无遮挡永久免费 | 99精品人妻无码专区在线视频区 | 免费无毒av | 男人添女人下部高潮视频 | 国产成人在线视频免费观看 | 99re只有精品 | 久久人人添人人爽添人人片 | 欧美午夜性春猛交 | 伊人久久中文 | 天天舔天天操 | 欧美大片一区二区三区 | 欧美成人精品一区二区 | 不卡在线一区 | 日韩午夜在线观看 | 999精彩视频 | 国产热99 | 免费人成自慰网站 | 第四色激情 | 天堂网www| 一道本一区 | 成人免费毛片xxx | 污漫网站 | 欧美性综合 | 亚洲色图图片 | 另类第一页 | 黄网视频在线观看 | 成人h片在线观看 | 亚洲最大视频网 | 午夜精品一区二区三区三上悠亚 | 夜夜草网站 | 美女大黄网站 | 欧美性成人| 67194少妇在线观看 | 蜜桃视频在线观看一区二区 | 四虎精品欧美一区二区免费 | 日韩福利一区二区 | 丝袜淫脚 | 免费黄色在线视频 | 国产精品一区二区人人爽 | 理论片琪琪午夜电影 | 丰满岳跪趴高撅肥臀尤物在线观看 | 久久无码国产视频 | 色窝窝综合色窝窝久久 | 久久av影视 | 国产盗摄一区二区三区 | 国产91对白在线播放 | 性做久久久久久久免费看 | 亚洲天堂一级片 | 国产在线高潮 | 综合99 | 足疗店女技师按摩毛片 | 免费涩涩视频 | 美女91网站 | 黄色不卡av | 卡通动漫精品一区二区三区 | 涩涩涩av | 操夜夜 | 国产色视频网站 | 欧美 日韩 国产 亚洲 色 | 国产精品一区二区av | 成人一区二区三区视频 | 狠狠干天天操 | 最近中文字幕mv免费高清在线 | 精品婷婷色一区二区三区蜜桃 | 全部免费毛片在线播放高潮 | 久久精品观看 | 一级视频在线观看 | 波多野结衣一区二区在线 | 亚洲av女人18毛片水真多 | 完全免费av | 欧美日韩亚洲精品一区二区 | 免费一级特黄3大片视频 | 欧美精品一二 | 亚洲天堂av线 | 欧美性生活网站 | 免费观看nba乐趣影院 | 人人插人人草 | 免费日皮视频 | 久久一二区 | 国产三级在线 | 欧美性猛交一区二区三区精品 | 男人猛吃奶女人爽视频 | 中国美女一级看片 | 欧美视频第一区 | 欧美乱轮 | 在线免费观看一区二区三区 | 91精品国产乱码久久久久久久久 |