数据备份 - 如何用ThinkPHP开发一个数据库备份功能

原创
2016-06-06 20:42:36 971浏览

如何用ThinkPHP开发一个数据库备份功能

就是各大CMS的数据库备份还原功能如何实现

回复内容:

如何用ThinkPHP开发一个数据库备份功能

就是各大CMS的数据库备份还原功能如何实现

从开源博客系统Emlog里找了一段:
https://github.com/emlog/emlog/blob/master/src/admin/data.php

/**
 * 备份数据库结构和所有数据
 *
 * @param string $table 数据库表名
 * @return string
 */
function dataBak($table){
    $DB = MySql::getInstance();
    $sql = "DROP TABLE IF EXISTS $table;\n";
    $createtable = $DB->query("SHOW CREATE TABLE $table");
    $create = $DB->fetch_row($createtable);
    $sql .= $create[1].";\n\n";

    $rows = $DB->query("SELECT * FROM $table");
    $numfields = $DB->num_fields($rows);
    $numrows = $DB->num_rows($rows);
    while ($row = $DB->fetch_row($rows)){
        $comma = "";
        $sql .= "INSERT INTO $table VALUES(";
        for ($i = 0; $i < $numfields; $i++){
            $sql .= $comma."'".mysql_escape_string($row[$i])."'";
            $comma = ",";
        }
        $sql .= ");\n";
    }
    $sql .= "\n";
    return $sql;
}
声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。