首页 > php与数据库 > 一个简单php数据库备份程序

一个简单php数据库备份程序

php备份mysql数据库是很多个人站长网站所具备的功能,当然如果你要备份几个GB或更大的数据库时php备份方法感觉有点吃力了。

PHP 备份 mysql 数据库的源代码,在完善的 PHP+Mysql 项目中,在后台都会有备份 Mysql 数据库的功能,有了这个功能,我们就不用再使用 FTP 或者使用 mysql 的管理工具进行 mysql 数据库下载了,非常方便,对于想做这样功能的 phper 来说,其实原理并不是很麻烦,主要有以下三点:

一,一定要连接数据库,这样才能通过 SQL 语句打印出 mysql 数据表,二,通过 PHP 的文件操作函数进行数据库的操作,包括创建保存 mysql 数据库的文件夹,这一步主要就是新建文件的步骤,三,将 mysql 数据库进行保存下来。

通过这样的原理,我们就可以制作出一个属于自己的备份数据库的功能了,下面是一个php数据库备份的源代码,主要结构是依据上面的三点进行的,源码是由几个方法组成的,我们也可以将其封装成为自己的 php 类。举一反三,希望 phper 能在此基础上设计出适合自己的 mysql 数据库备份功能源码

<?php
/** 备份数据库 生成.sql文件
 * @param $browseinfo  String  浏览器版本
 * return $browseinfo
 */
function createsql() {
    //创建个日期
    $timer1 = time();
    $path = "my_sql/";
    $content = gettables();
    $filename = $path . $timer1 . ".sql";
    //先判断文件夹在不在
    if (!file_exists($path)) {
        //如果不存在生成这个目录,0777表示最大的读写权限
        if (mkdir($path, 0777)) {
            //echo"新建立目录";
            
        }
    }
    //判断文件是否存在
    if (!file_exists($filename)) {
        //如果文件不存在,则创建文件
        @fopen($filename, "w");
        //判断文件是否可写
        if (is_writable($filename)) {
            //打开文件以添加方式即"a"方式打开文件流
            if (!$handle = fopen($filename, "a")) {
                echo "文件不可打开";
                exit();
            }
            if (!fwrite($handle, $content)) {
                echo "文件不可写";
                exit();
            }
            //关闭文件流
            fclose($handle);
            echo "生成文件并保存首次内容";
        } else {
            echo "文件$filename不可写";
        }
    } else {
        if (is_writable($filename)) {
            //以添加方式打开文件流
            if (!$handle = fopen($filename, "a")) {
                echo "文件不可打开";
                exit();
            }
            fclose($handle);
        } else {
            echo "文件$filename不可写";
        }
    }
}
/**
 * 获得数据库中的表名
 * return $str 循环生成数据库建表和插入值的sql语句
 */
function gettables() {
    $mysqli = new mysqli("localhost", "root", "", "bbs");
    $str = '';
    if ($result = $mysqli->query("SHOW TABLES")) {
        while ($row = $result->fetch_row()) {
            $str.= data2sql($row[0]) . "<br/>";
        }
        $mysqli->close();
        return $str;
    }
}
/**
 * 获得数据库中的表结构和值
 * return $tabledump 返回一个表中的结构和值的sql语句
 */
function data2sql($table) {
    $mysqli = new mysqli("localhost", "root", "", "bbs");
    /* check connection */
    if (mysqli_connect_errno()) {
        printf("Connect failed: %sn", mysqli_connect_error());
        exit();
    }
    $tabledump = "DROP TABLE IF EXISTS $table;n";
    $result = $mysqli->query("SHOW CREATE TABLE $table");
    $create = $result->fetch_row();
    $tabledump.= $create[1] . ";nn";
    $rows = $mysqli->query("SELECT * FROM $table");
    $numfields = $rows->num_rows;
    while ($row = $rows->fetch_row()) {
        $comma = "";
        $tabledump.= "INSERT INTO $table VALUES(";
        for ($i = 0; $i < $numfields; $i++) {
            $tabledump.= $comma . "'" . mysql_escape_string($row[$i]) . "'";
            $comma = ",";
        }
        $tabledump.= ");\n";
    }
    $tabledump.= "\n";
    return $tabledump;
}
?>


永久链接:http://www.phprm.com/database/52529.html

转载随意!带上文章地址吧。

标签:fopen

相关文章

发表留言