tp5.1导出mysql_tp5备份mysql数据库(备忘)

se.php里面配置即可,这里直接上方法//数据库备份

public function backups()

{

//1.获取数据库信息

$info = Db::getConfig();

$dbname = $info['database'];

//2.获取数据库所有表

$tables = Db::query("show tables");

//3、组装头部信息

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

$path = ROOT_PATH.'/data/';

$database = $dbname;   //获取当前数据库

$info  = "-- ----------------------------\r\n";

$info .= "-- 日期:".date("Y-m-d H:i:s",time())."\r\n";

$info .= "-- MySQL - 5.5.52-MariaDB : Database - ".$database."\r\n";

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

$info .= "SET NAMES utf8;\r\nSET FOREIGN_KEY_CHECKS = 0;\r\n\r\n";

//4、检查目录是否存在

if (is_dir($path)) {

if (is_writable($path)) {

} else {

echo '目录不可写'; exit();

}

} else {

mkdir($path,0777,true);

}

//5、保存的文件名称

$file_name = $path.$database.'_'.date('Ymd_His').'.sql';

file_put_contents($file_name, $info, FILE_APPEND);

//6、循环表,写入数据

foreach ($tables as $k => $v) {

$val = $v["Tables_in_$database"];

$sql = "SELECT * FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME='$val' AND TABLE_SCHEMA='$dbname'";

$res = Db::query($sql);

$max_num = Db::table("$val")->order('id desc')->value('id');

//查询表结构

$info_table = "-- ----------------------------\r\n";

$info_table .= "-- Table structure for `$val`\r\n";

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

$info_table .= "DROP TABLE IF EXISTS `$val`;\r\n";

if (count($res) 

continue;

}

$info_table .= "CREATE TABLE `$val` (\n\r\t";

foreach ($res as $kk => $vv) {

$info_table .= " `".$vv['COLUMN_NAME']."` ";

$info_table .= $vv['COLUMN_TYPE'];

//是否允许空值

if ($vv['IS_NULLABLE'] == 'NO') {

$info_table .= " NOT NULL ";

}

//判断主键

if ($vv['EXTRA']) {

$info_table .= " AUTO_INCREMENT ";

$key = $vv['COLUMN_NAME'];

}

//编码

if ($vv['CHARACTER_SET_NAME']) {

$info_table .= " CHARACTER SET ".$vv['CHARACTER_SET_NAME'];

}

//字符集

if ($vv['COLLATION_NAME']) {

$info_table .= " COLLATE ".$vv['COLLATION_NAME'];

}

//默认数值

if ($vv['COLUMN_DEFAULT']) {

$info_table .= " DEFAULT ".$vv['COLUMN_DEFAULT'];

}

//注释

if ($vv['COLUMN_COMMENT']) {

$info_table .= " COMMENT '".$vv['COLUMN_COMMENT']."',\n\r\t";

}

}

$info_table .= " PRIMARY KEY (`$key`) USING BTREE";

$info_table .= "\n\r) ENGINE = MyISAM AUTO_INCREMENT $max_num CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;\r\n\r\n";

//查询表数据

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

$info_table .= "-- Data for the table `$val`\r\n";

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

file_put_contents($file_name,$info_table,FILE_APPEND);

$sql_data = "select * from $val";

$data = Db::query($sql_data);

$count= count($data);

if ($count 

continue;

}

foreach ($data as $key => $value) {

$sqlStr = "INSERT INTO `$val` VALUES (";

foreach($value as $v_d){

$v_d = str_replace("'","\'",$v_d);

$sqlStr .= "'".$v_d."', ";

}

//需要特别注意对数据的单引号进行转义处理

//去掉最后一个逗号和空格

$sqlStr = substr($sqlStr,0,strlen($sqlStr)-2);

$sqlStr .= ");\r\n";

file_put_contents($file_name,$sqlStr,FILE_APPEND);

}

$info = "\r\n";

file_put_contents($file_name,$info,FILE_APPEND);

}

//7、下载数据到本地

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($file_name));

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

readfile($file_name);

DownloadFile($path.$file_name);

$this->success("数据已备份");

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值