tp5数据库备份代码
冰貂主人
2023-12-07 17:38:31
0

问题描述:

一直使用tp5,做个数据库备份试试。

解决办法:

第一步:html页面
<a href="{:url(index/data)}">
数据库备份</a>

第二步:controller


//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.'public/static/backup/';

$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")->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) < 1) {
        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 < 1) {
        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("数据已备份");

相关内容

tp5数据库备份代码
问题描述: 一直使用tp5.0,做个数据库备份试试。 解决办法: ...
2023-12-07 17:38:31

热门资讯

tp5 jquery判断手机端... application--common.php中添加如下代码 //函数作用是判断用户打开的是手机端还...
Laravel 5.5 .No... 创建了新的laravel项目后, 运行提示:No application encryption ke...
php 打印date函数出现错... 问题描述: 我使用的是phpstudy,在练习时间函数的时候,打印出现在的时间,date(Y-m-d...
生成随机字符唯一标识符guid... /** * @param $length * @return string * 生成随机字符串 */...
layui缩略图 div class=layui-form-item label class=layui-form-l...
php函数substr_rep... php函数substr_replace从某个位置替换或删除或插入字符串
Laravel 引入自定义类库... 强烈建议引入的类 都是含有命名空间的,这样使用起来就不会出现重名的情况。!!当然,没有命名空间也可以...
object json转化为数... //调用api 程序,通知商户订单异常 20200314 public function callt...
Laravel 查看SQL操作... 方法一:临时打印操作记录 DB::connection()-enableQueryLog(); # ...
php银行开放平台接口:pfx... 问题描述: 对接易通银行,他们的服务开放平台是java开发,而我的是php,现在需要php版本的SD...