搜尋
首頁php教程php手册thinkphp备份数据库的方法分享

这篇文章主要介绍了thinkphp备份数据库的方法分享,非常的简单实用,推荐给有需要的小伙伴们

貌似THINKPHP没有备份数据库的方法,所以我自己写了一个,数据库连接和事务处理用的是pdo,如果有需要的可以联系我,写个mysql或者mysqli的

复制代码 代码如下:


class SqlAction extends Action{
function outsql(){
header(“Content-Type:text/html;charset=utf-8″);
/*用C方法读取数据库配置*/
$host=C(‘DB_HOST');
$db_name=C(‘DB_NAME');
$user=C(‘DB_USER');
$password=C(‘DB_PWD');
/*调用导出数据库的私有方法*/
$outstream=$this->outputSql($host, $dbname, $user, $password);
/*下载导出数据库*/
header(“Content-Disposition: attachment; filename=$dbname.sql”);
echo $outstream;
}
/*
* 数据库导出函数outputSql
* 用PDO方式导出数据库数据
* $host 主机名 如localhost
* $dbname 数据库名
* $user 用户名
* $password 密码
* $flag 标志位0或1 0为仅导出数据库结构 1为导出数据库结构和数据 默认为1
*/
private function outputSql($host, $dbname, $user, $password, $flag=1) {
try {
$pdo = new PDO(“mysql:host=$host;dbname=$dbname”, $user, $password); //连接数据库
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); //设置调优参数,遇到错误抛出异常
} catch (PDOException $e) {
echo $e->getMessage(); //如果连接异常则抛出错误信息
exit;
}
$mysql = “DROP DATABASE IF EXISTS `$dbname`;\n”; //$mysql装载sql语句,这里如果存在数据库则drop该数据库
$creat_db=$pdo->query(“show create database $dbname”)->fetch();//用show create database查看sql语句
preg_match(‘/DEFAULT CHARACTER SET(.*)\*/', $creat_db[‘Create Database'],$matches);//正则取出DEFAULT CHARACTER SET 后面的字符集
$mysql.=”CREATE DATABASE `$dbname` DEFAULT CHARACTER SET $matches[1]”;//该语句如CREATE DATABASE `test_db` DEFAULT CHARACTER SET utf8
/*查找该数据库的字符整序如COLLATE utf8_general_ci*/
$db_collate=$pdo->query(“SELECT DEFAULT_COLLATION_NAME FROM information_schema.SCHEMATA WHERE SCHEMA_NAME ='$dbname' LIMIT 1″)->fetch();
$mysql.=”COLLATE “.$db_collate[‘DEFAULT_COLLATION_NAME'].”;\nUSE `$dbname`;\n\n”;
$statments = $pdo->query(“show tables”); //返回结果集,show tables检视所有表名
foreach ($statments as $value) {//遍历此结果集,,导出每个表名对应的信息
$table_name = $value[0]; //获取该表名
$mysql.=”DROP TABLE IF EXISTS `$table_name`;\n”; //每个表前都准备Drop语句
$table_query = $pdo->query(“show create table `$table_name`”); //取出该表建表信息的结果集
$create_sql = $table_query->fetch(); //利用fetch方法取出该结果集对应的数组
$mysql.=$create_sql[‘Create Table'] . “;\r\n\r\n”; //写入建表信息
if ($flag != 0) {//如果标志位不是0则继续取出该表内容生成insert语句
$iteams_query = $pdo->query(“select * from `$table_name`”); //取出该表所有字段结果集
$values = “”; //准备空字符串装载insert value值
$items = “”; //准备空字符串装载该表字段名
while ($item_query = $iteams_query->fetch(PDO::FETCH_ASSOC)) { //用关联查询方式返回表中字段名和值的数组
$item_names = array_keys($item_query); //取出该数组键值 即字段名
$item_names = array_map(“addslashes”, $item_names); //将特殊字符转译加\
$items = join(‘`,`', $item_names); //联合字段名 如:items1`,`item2 `符号为反引号 键盘1旁边 字段名用反引号括起
$item_values = array_values($item_query); //取出该数组值 即字段对应的值
$item_values = array_map(“addslashes”, $item_values); //将特殊字符转译加\
$value_string = join(“‘,'”, $item_values); //联合值 如:value1′,'value2 值用单引号括起
$value_string = “(‘” . $value_string . “‘),”; //值两边加括号
$values.=”\n” . $value_string; //最后返回给$value
}
if ($values != “”) {//如果$values不为空,即该表有内容
//写入insert语句
$insert_sql = “INSERT INTO `$table_name` (`$items`) VALUES” . rtrim($values, “,”) . “;\n\r”;
//将该语句写入$mysql
$mysql.=$insert_sql;
}
}

}
return $mysql;
}
}
?>

是不是很实用的功能呢,小伙伴们可以直接移植到自己的项目中去的。

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境